HDU.1285 确定比赛名次 (拓扑排序 TopSort)
2024-08-31 07:37:16
HDU.1285 确定比赛名次 (拓扑排序 TopSort)
题意分析
裸的拓扑排序
详解请移步
算法学习 拓扑排序(TopSort)
只不过这道的额外要求是,输出字典序最小的那组解。那么解决方案就是每次扫描1-n节点的入度,并且只取出1个编号最小的节点,处理他然后继续取,直到所有节点取出,即可满足字典序最小。
代码总览
#include <iostream>
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <sstream>
#include <set>
#include <map>
#include <queue>
#include <stack>
#include <cmath>
#define nmax 505
#define MEM(x) memset(x,0,sizeof(x))
using namespace std;
int indegree[nmax];
vector<int> v[nmax];
int n,m;
queue<int> ans;
bool suc = true;bool isfirst = true;
void output()
{
while(!ans.empty()){
int t = ans.front(); ans.pop();
if(isfirst){printf("%d",t); isfirst =false;}
else printf(" %d",t);
}
//printf("\n");
}
void topsort()
{
queue<int> q;
while(1){
for(int i = 1; i<=n;++i){
if(indegree[i] == 0){
q.push(i);
ans.push(i);
indegree[i] = -1;
break;
}
}
if(q.empty()) break;
while(!q.empty()){
int t = q.front();q.pop();
for(int i = 0; i<v[t].size();++i){
int tt = v[t][i];
if(indegree[tt] == -1){
suc =false;
break;
}else
indegree[tt] --;
}
v[t].clear();
if(!suc) break;
}
if(!suc) break;
output();
}
if(suc && ans.size() != n) suc = false;
}
int main()
{
//freopen("in.txt","r",stdin);
while(scanf("%d%d",&n,&m) != EOF){
MEM(indegree); suc = true;isfirst = true;
for(int i = 0; i<m; ++i){
int a,b;
scanf("%d%d",&a,&b);
indegree[b]++;
v[a].push_back(b);
}
topsort();
printf("\n");
}
return 0;
}
最新文章
- Android File存储
- Android BinderService 过程
- C#图像处理(各种旋转、改变大小、柔化、锐化、雾化、底片、浮雕、黑白、滤镜效果)
- android_demo01
- aspnet excel导入导出SQLserver
- .net framework 源码调试 与 问题解决
- IE6、7 a链接内图片加滤镜后导致a标签链接失效问题解决
- 玩转python之测试一个对象是否是类字符串
- 基于HTTP协议的下载功能实现
- 优化js脚本设计,防止浏览器假死
- hibernate框架(4)---主键生成策略
- Linux中Mysql的简介和安装
- jenkins中shell脚本编写的两个注意点
- C#网络编程技术微软Socket实战项目演练(三)
- window Form中使用Font Awesome z
- 配置SSH使用秘钥登录
- Codeforces.788C.The Great Mixing(bitset DP / BFS)
- 实训六(Cocos2dx游戏分享到微信朋友圈----AppID的获取)
- PHP查找与搜索数组元素
- java基础62 JavaScript中的函数(网页知识)
热门文章
- sqlserver 循环赋值变量
- 汽车后市场:数据入口在哪里?不看你就OUT啦!
- Linux用户及权限
- 【JAVA】关于java中 类.class.getResource(";/";).getPath()获取路径有空格的问题
- go通过第三方库 mahonia gbk 转utf8
- opencv-学习笔记(1)常用函数和方法。
- php 安全方面面试题
- [leetcode-753-Open the Lock]
- JS中Document节点总结
- Graph Theory