hdu oj 1285 确定比赛名次
2024-09-30 18:33:42
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;
}
最新文章
- SOA架构设计(转发)
- encodeURI来解决URL传递时的中文问题
- BZOJ1858[Scoi2010]序列操作 题解
- linux 2.6.21版本的内核合法的MAC地址
- PC上面的蓝牙的通信(C#)
- Tomcat配置NIO
- QT 串口通信 数据16进制发送
- Loggerly技术架构
- 解决SQL查询总是超时已过期
- [转]使用sklearn进行集成学习——理论
- 全方位解读";CPU load average";
- JAXB(Java Architecture for XML Binding)
- kivy sdl2 - ImportError: DLL load failed: 找不到指定的模块。
- 4、下行短信发送WebService、下行短信发送服务 -功能详细设计 --短信平台
- noip第26课资料
- 递归 + OS模块
- 实验吧 ASCII艺术
- requests库入门14-Cookie
- jq demo 简单的图片懒加载效果
- day15_雷神_前端03
热门文章
- leetcode_951. Flip Equivalent Binary Trees_二叉树遍历
- 浮动qq客服备份代码
- [Python3网络爬虫开发实战] 1.2.3-ChromeDriver的安装
- 18Spring后置通知
- python 开发搭建目录规范
- history.go history.back()
- 集训第四周(高效算法设计)I题 (贪心)
- AutoMapper 使用总结1
- 【XML】-- C#读取XML中元素和属性的值
- Leetcode 139.单词拆分