hdu oj 1285 确定比赛名次

题目:

确定比赛名次

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Total Submission(s): 17378    Accepted Submission(s): 6939
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
 

解析:

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int imap[501][501],indegree[501];
void topsort(int n)
{
int i,j,k;
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
if(indegree[j]==0)
{
indegree[j]--;
if(i==n) printf("%d\n",j);
else printf("%d ",j);
for(k=1;k<=n;k++)
if(imap[j][k]==1)
indegree[k]--;
break;
}
}
}
}
int main()
{
int m,n,a,b;
while(scanf("%d %d",&n,&m)!=EOF)
{
memset(imap,0,sizeof(imap));
memset(indegree,0,sizeof(indegree));
while(m--)
{
scanf("%d %d",&a,&b);
if(!imap[a][b])
{
imap[a][b]=1;
indegree[b]++;
}
}
topsort(n);
}
return 0;
}

最新文章

  1. SOA架构设计(转发)
  2. encodeURI来解决URL传递时的中文问题
  3. BZOJ1858[Scoi2010]序列操作 题解
  4. linux 2.6.21版本的内核合法的MAC地址
  5. PC上面的蓝牙的通信(C#)
  6. Tomcat配置NIO
  7. QT 串口通信 数据16进制发送
  8. Loggerly技术架构
  9. 解决SQL查询总是超时已过期
  10. [转]使用sklearn进行集成学习——理论
  11. 全方位解读&quot;CPU load average&quot;
  12. JAXB(Java Architecture for XML Binding)
  13. kivy sdl2 - ImportError: DLL load failed: 找不到指定的模块。
  14. 4、下行短信发送WebService、下行短信发送服务 -功能详细设计 --短信平台
  15. noip第26课资料
  16. 递归 + OS模块
  17. 实验吧 ASCII艺术
  18. requests库入门14-Cookie
  19. jq demo 简单的图片懒加载效果
  20. day15_雷神_前端03

热门文章

  1. leetcode_951. Flip Equivalent Binary Trees_二叉树遍历
  2. 浮动qq客服备份代码
  3. [Python3网络爬虫开发实战] 1.2.3-ChromeDriver的安装
  4. 18Spring后置通知
  5. python 开发搭建目录规范
  6. history.go history.back()
  7. 集训第四周(高效算法设计)I题 (贪心)
  8. AutoMapper 使用总结1
  9. 【XML】-- C#读取XML中元素和属性的值
  10. Leetcode 139.单词拆分