hdu 1811 Rank of Tetris (拓扑 & 并查集)

Rank of Tetris

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4323    Accepted Submission(s): 1220


Problem Description
自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。

为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜,定时更新,名堂要比福布斯富豪榜还响。关于如何排名,这个不用说都知道是根据Rating从高到低来排,如果两个人具有相同的Rating,那就按这几个人的RP从高到低来排。

终于,Lele要开始行动了,对N个人进行排名。为了方便起见,每个人都已经被编号,分别从0到N-1,并且编号越大,RP就越高。
同时Lele从狗仔队里取得一些(M个)关于Rating的信息。这些信息可能有三种情况,分别是"A > B","A = B","A < B",分别表示A的Rating高于B,等于B,小于B。

现在Lele并不是让你来帮他制作这个高手榜,他只是想知道,根据这些信息是否能够确定出这个高手榜,是的话就输出"OK"。否则就请你判断出错的原因,到底是因为信息不完全(输出"UNCERTAIN"),还是因为这些信息中包含冲突(输出"CONFLICT")。
注意,如果信息中同时包含冲突且信息不完全,就输出"CONFLICT"。
 
Input
本题目包含多组测试,请处理到文件结束。
每组测试第一行包含两个整数N,M(0<=N<=10000,0<=M<=20000),分别表示要排名的人数以及得到的关系数。
接下来有M行,分别表示这些关系
 
Output
对于每组测试,在一行里按题目要求输出
 
Sample Input
3 3
0 > 1
1 < 2
0 > 2
4 4
1 = 2
1 > 3
2 > 0
0 > 1
3 3
1 > 0
1 > 2
2 < 1
 
Sample Output
OK
CONFLICT
UNCERTAIN
 
Author
linle
 
Source
 
Recommend
lcy   |   We have carefully selected several similar problems for you:  1198 1829 1558 1325 1213 
 
 1 //62MS    744K    1657 B    G++
 2 /*
 3 
 4     拓扑排序+并查集:
 5         题意比较明了,就是要排序,'='号用并查集处理,先处理完再
 6     进行拓扑排序。 
 7 
 8 */
 9 #include<iostream>
10 #include<queue>
11 #include<vector>
12 using namespace std;
13 vector<int>next[10005];
14 int in[10005],a[20005],b[20005];
15 char c[20005];
16 int set[10005];
17 int n,m,sum;  //sum最后不为0则表示有环,排名矛盾 
18 int find(int x)
19 {
20     if(x==set[x]) return x;
21     return find(set[x]);
22 }
23 int merge(int a,int b)
24 {
25     int x=find(a);
26     int y=find(b);
27     if(x==y) return 0;
28     if(x>y) set[x]=y;
29     else set[y]=x;
30     return 1; 
31 }
32 void topo()
33 {
34     int uncertain=0;
35     queue<int>Q;
36     for(int i=0;i<n;i++) 
37         if(in[i]==0 && find(i)==i){
38             Q.push(i);
39         }
40     while(!Q.empty()){
41         if(Q.size()>1) uncertain=1;  //队列同时存在多个元素,则排名不明确 
42         int u=Q.front();
43         Q.pop();
44         sum--;
45         for(int i=0;i<next[u].size();i++)
46             if(--in[next[u][i]]==0) 
47                 Q.push(next[u][i]);
48     }
49     if(sum>0) puts("CONFLICT");
50     else if(uncertain) puts("UNCERTAIN");
51     else puts("OK");
52 }
53 int main(void)
54 {
55     while(scanf("%d%d",&n,&m)!=EOF)
56     {
57         sum=n;
58         for(int i=0;i<=n;i++){
59             next[i].clear();
60             in[i]=0;
61             set[i]=i; 
62         }
63         for(int i=0;i<m;i++){
64             scanf("%d %c %d",&a[i],&c[i],&b[i]);
65             if(c[i]=='='){
66                 if(merge(a[i],b[i])) sum--;
67             } 
68         }
69         for(int i=0;i<m;i++){
70             int x=find(a[i]);
71             int y=find(b[i]);
72             if(c[i]=='>'){
73                 next[x].push_back(y);
74                 in[y]++;
75             }
76             if(c[i]=='<'){
77                 next[y].push_back(x);
78                 in[x]++;
79             }
80         }
81         topo();
82     }
83     return 0;
84 }
原文地址:https://www.cnblogs.com/GO-NO-1/p/3613557.html