hdu 1285 确定比赛名次
来源:互联网 发布:下载淘宝助理免费 编辑:程序博客网 时间:2024/06/06 03:33
题目链接:点这里
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 31 22 34 3
Sample Output
1 2 4 3
【分析】
经典的最简单的拓扑排序。算是学习拓扑吧。
【代码】
#include<iostream>#include<cstdio>#include<cstring>#include<string.h>#include<algorithm>#include<vector>#include<cmath>#include<stdlib.h>#include<time.h>#include<stack>#include<set>#include<map>#include<queue>#include<sstream>using namespace std;#define rep0(i,l,r) for(int i = (l);i < (r);i++)#define rep1(i,l,r) for(int i = (l);i <= (r);i++)#define rep_0(i,r,l) for(int i = (r);i > (l);i--)#define rep_1(i,r,l) for(int i = (r);i >= (l);i--)#define MS0(a) memset(a,0,sizeof(a))#define MS1(a) memset(a,-1,sizeof(a))#define MSi(a) memset(a,0x3f,sizeof(a))#define sin1(a) scanf("%d",&(a))#define sin2(a,b) scanf("%d%d",&(a),&(b))#define sll1(a) scanf("%lld",&(a))#define sll2(a,b) scanf("%lld%lld",&(a),&(b))#define sdo1(a) scanf("%lf",&(a))#define sdo2(a,b) scanf("%lf%lf",&(a),&(b))#define inf 0x3f3f3f3f#define lson i<<1,l,mid#define rson ((i<<1)|1),mid+1,r#define uint unsigned inttypedef pair<int,int> PII;#define A first#define B second#define pb push_back#define MK make_pair#define ll long longtemplate<typename T>void read1(T &m){ T x=0,f=1; char ch=getchar(); while(ch<'0'||ch>'9') { if(ch=='-')f=-1; ch=getchar(); } while(ch>='0'&&ch<='9') { x=x*10+ch-'0'; ch=getchar(); } m = x*f;}template<typename T>void read2(T &a,T &b){ read1(a); read1(b);}template<typename T>void read3(T &a,T &b,T &c){ read1(a); read1(b); read1(c);}template<typename T>void out(T a){ if(a>9) out(a/10); putchar(a%10+'0');}template<typename T>void outn(T a){ if(a>9) out(a/10); putchar(a%10+'0'); puts("");}using namespace std;///---------------------------------------------------------------------------------bool mat[521][521];int in[521];priority_queue<int,vector<int>,greater<int> >q;void topo(int n){ rep1(i,1,n) { if(in[i]==0) q.push(i); } int c=1; while(!q.empty()) { int v=q.top(); q.pop(); if(c!=n) cout<<v<<" "; else cout<<v<<endl; c++; rep1(i,1,n) { if(!mat[v][i]) continue; in[i]--; if(!in[i]) q.push(i); } }}int main(){// freopen("in.txt","r",stdin); int n,m; while(sin2(n,m)!=EOF) { memset(mat,false,sizeof(mat)); memset(in,0,sizeof(in)); int from,to; while(m--) { read2(from,to); if(mat[from][to]) continue; in[to]++; mat[from][to]=true; } topo(n); } return 0;}
阅读全文
0 0
- HDU 1285 确定比赛名次
- hdu 1285 确定比赛名次
- HDu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- HDU-1285-确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- hdu 1285 确定比赛名次
- Hdu 1285 确定比赛名次
- HDU 1285 确定比赛名次
- HDU 1285 确定比赛名次
- hdu 1285 确定比赛名次
- HDU 1285 确定比赛名次
- HDU - 1285 确定比赛名次
- 数据结构与算法(二):二叉树前序,中序,后序遍历详解
- OrientDB初识-学习文档
- 智能指针(一)之引入
- mysql的单引号和双引号的区别??(基本没有)
- 需求处理的妥协和更好的设计过程模型
- hdu 1285 确定比赛名次
- 多线程问题(生产者和消费者)
- oozie框架案例之shellAction
- 背包四讲及其优化与证明
- qwt绘制,以及画面缩放、平移操作
- 蓄水池抽样算法 (Reservoir Sampling Algorithm)
- 小白学tkinter(Listbox组件 多选组件)
- 鹧鸪天·彩袖殷勤捧玉钟
- 大暴搜 [NOIP2009]靶形数独