首页 > 代码库 > HDU 1285 拓扑排序
HDU 1285 拓扑排序
确定比赛名次
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 11543 Accepted Submission(s): 4603
Problem Description
有N个比赛队(1<=N<=500),编号依次为1,2,3,。。。。,N进行比赛,比赛结束后,裁判委员会要将所有参赛队伍从前往后依次排名,但现在裁判委员会不能直接获得每个队的比赛成绩,只知道每场比赛的结果,即P1赢P2,用P1,P2表示,排名时P1在P2之前。现在请你编程序确定排名。
Input
输入有若干组,每组中的第一行为二个数N(1<=N<=500),M;其中N表示队伍的个数,M表示接着有M行的输入数据。接下来的M行数据中,每行也有两个整数P1,P2表示即P1队赢了P2队。
Output
给出一个符合要求的排名。输出时队伍号之间有空格,最后一名后面没有空格。
其他说明:符合条件的排名可能不是唯一的,此时要求输出时编号小的队伍在前;输入数据保证是正确的,即输入数据确保一定能有一个符合要求的排名。
其他说明:符合条件的排名可能不是唯一的,此时要求输出时编号小的队伍在前;输入数据保证是正确的,即输入数据确保一定能有一个符合要求的排名。
Sample Input
4 3
1 2
2 3
4 3
Sample Output
1
2
4
3
WA了一次 ,原因是可能有重复的,比如输入两两次5 3
附个数据:
6 115 35 35 15 45 23 13 26 46 24 24 2结果是:5 3 1 6 4 2
代码:
1 #include <cstdio> 2 #include <cstring> 3 #include <algorithm> 4 #include <iostream> 5 #include <stack> 6 #include <queue> 7 #include <map> 8 #include <vector> 9 #include <sstream>10 #include <string>11 using namespace std;12 13 struct mem{14 int x, y;15 }a[505];16 17 bool cmp(mem a,mem b){18 if(a.x==b.x) return a.y<b.y;19 return a.x<b.x;20 }21 22 main()23 {24 int du[505];25 int ma[505][505];26 vector<int>ve[505];27 int n, m, i, j, k;28 while(scanf("%d %d",&n,&m)==2){29 memset(du,0,sizeof(du));30 memset(ma,0,sizeof(ma));31 for(i=0;i<=n;i++) ve[i].clear();32 for(i=0;i<m;i++) {33 scanf("%d %d",&a[i].x,&a[i].y);34 if(!ma[a[i].x][a[i].y])35 {36 du[a[i].y]++;37 ve[a[i].x].push_back(a[i].y);38 }39 40 ma[a[i].x][a[i].y]=1;41 }42 // sort(a,a+m,cmp);43 /* 44 for(i=1;i<=n;i++){45 printf("%d ",du[i]);46 }47 cout<<endl<<endl;*/48 int b[505], f=0, l=0;49 for(k=1;k<=n;k++){50 f=0;51 for(i=1;i<=n;i++){52 if(du[i]==0) {53 for(j=0;j<ve[i].size();j++){54 du[ve[i][j]]--;55 }56 b[l++]=i;57 du[i]=-1;58 f++;59 break;60 }61 62 }63 if(!f) break;64 }65 printf("%d",b[0]);66 for(i=1;i<l;i++) printf(" %d",b[i]);67 cout<<endl;68 69 }70 }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。