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;
}

最新文章

  1. Android File存储
  2. Android BinderService 过程
  3. C#图像处理(各种旋转、改变大小、柔化、锐化、雾化、底片、浮雕、黑白、滤镜效果)
  4. android_demo01
  5. aspnet excel导入导出SQLserver
  6. .net framework 源码调试 与 问题解决
  7. IE6、7 a链接内图片加滤镜后导致a标签链接失效问题解决
  8. 玩转python之测试一个对象是否是类字符串
  9. 基于HTTP协议的下载功能实现
  10. 优化js脚本设计,防止浏览器假死
  11. hibernate框架(4)---主键生成策略
  12. Linux中Mysql的简介和安装
  13. jenkins中shell脚本编写的两个注意点
  14. C#网络编程技术微软Socket实战项目演练(三)
  15. window Form中使用Font Awesome z
  16. 配置SSH使用秘钥登录
  17. Codeforces.788C.The Great Mixing(bitset DP / BFS)
  18. 实训六(Cocos2dx游戏分享到微信朋友圈----AppID的获取)
  19. PHP查找与搜索数组元素
  20. java基础62 JavaScript中的函数(网页知识)

热门文章

  1. sqlserver 循环赋值变量
  2. 汽车后市场:数据入口在哪里?不看你就OUT啦!
  3. Linux用户及权限
  4. 【JAVA】关于java中 类.class.getResource(&quot;/&quot;).getPath()获取路径有空格的问题
  5. go通过第三方库 mahonia gbk 转utf8
  6. opencv-学习笔记(1)常用函数和方法。
  7. php 安全方面面试题
  8. [leetcode-753-Open the Lock]
  9. JS中Document节点总结
  10. Graph Theory