zoukankan      html  css  js  c++  java
  • 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 }
  • 相关阅读:
    SQL Server 文件规划 位置规划
    在VS2008中使用WSE 3.0过程全记录
    关于CDC功能的答疑
    SQL Server 2008 : 基于策略的管理(PolicyBased Management)
    使用 Google Gears 开发离线应用
    SQL Server 2008 :安装
    WCF 之UserName身份验证全记录
    SQL Server 文件规划 文件组
    不可思议的SQLite
    使用Trigger让UpdatePanel外部的控件也支持无刷新异步调用
  • 原文地址:https://www.cnblogs.com/GO-NO-1/p/3613557.html
Copyright © 2011-2022 走看看