1 /*
  2     题意:这些信息可能有三种情况,分别是"A > B","A = B","A < B",分别表示A的Rating高于B,等于B,小于B。
  3
  4 现在Lele并不是让你来帮他制作这个高手榜,他只是想知道,根据这些信息是否能够确定出这个高手榜,是的话就输出"OK"。
  5 否则就请你判断出错的原因,到底是因为信息不完全(输出"UNCERTAIN"),还是因为这些信息中包含冲突(输出"CONFLICT")。
  6 注意,如果信息中同时包含冲突且信息不完全,就输出"CONFLICT"。
  7
  8    思路: 因为小于关系和大于关系可以转换一下位置! 这里的问题就在与如何正确的处理相等的关系!
  9    如果没有相等的关系,一个拓扑排序算法就可以搞定了! 既然元素相等,那么我们取相等元素中的某一个
 10    数来表示每一个数不是也行吗!?对,没错,用这个数来代替所有与之相等元素的数表示 '<'关系! 也就是
 11    转换成集合之间的关系的处理! 将每一个相等的元素集合看成一个点,这个点的代表就是集合的父亲节点!
 12
 13    那么如何来得到这个数呢?并查集最适合不过了!我们将相等的元素放入集合中!
 14    当 a<b时,通过getFather(a) < getFather(b)来处里a<b的关系,这里用邻接表进行处理!
 15 */
 16 #include<iostream>
 17 #include<cstring>
 18 #include<vector>
 19 #include<stack>
 20 using namespace std;
 21 int f[10005];
 22 int rank[10005];
 23 int n, m;
 24 int getFather(int x){
 25    return x==f[x] ? x : f[x]=getFather(f[x]);
 26 }
 27
 28 int Union(int a, int b){
 29    int fa=getFather(a), fb=getFather(b);
 30    if(fa!=fb){
 31       if(rank[fa]>rank[fb]){
 32          f[fb]=fa;
 33          rank[fa]+=rank[fb]+1;
 34       }
 35       else{
 36          f[fa]=fb;
 37          rank[fb]+=rank[fa]+1;
 38       }
 39       return 1;
 40    }
 41    return 0;
 42 }
 43
 44 int in[10005];
 45 int A[10005], B[10005];
 46 char ch[10005];
 47 vector<int>vx[10005];
 48 int conflict, uncertain;
 49 int sum;
 50
 51 /*void topoSort(){
 52     for(int j=1; j<=sum; ++j){
 53          int p=0, cnt=0;
 54          for(int i=1; i<=n; ++i)
 55             if(f[i]==i && in[i]==0){//f[i]==i表明 i是这个相等集合的代表元素,也就是这个集合所有元素的父节点
 56                p=i;
 57                ++cnt;
 58             }
 59          if(cnt==0){
 60             conflict=1;
 61             return;
 62          }
 63          if(cnt>1)
 64             uncertain=1;
 65          int len=vx[p].size();
 66          for(int i=0; i<len; ++i)
 67              --in[vx[p][i]];
 68          in[p]=-1;
 69     }
 70 }*/
 71
 72 stack<int>ss;
 73
 74 void topoSort(){
 75     for(int i=1; i<=n; ++i)
 76         if(f[i]==i && in[i]==0)//f[i]==i表明 i是这个相等集合的代表元素,也就是这个集合所有元素的父节点
 77             ss.push(i);
 78     if(ss.size()==0 && sum)
 79         conflict=1;
 80     while(!ss.empty()){
 81          int cnt=ss.size();
 82          int p=ss.top();
 83          --sum;//表示剩余多少个节点没有排序!
 84          ss.pop();
 85
 86          if(cnt>1)
 87             uncertain=1;
 88          int len=vx[p].size();
 89          for(int i=0; i<len; ++i)
 90              if(--in[vx[p][i]]==0)
 91                ss.push(vx[p][i]);
 92           if(ss.size()==0 && sum)
 93             conflict=1;
 94     }
 95 }
 96
 97 int main(){
 98     while(cin>>n>>m){
 99        for(int i=1; i<=n; ++i)
100           f[i]=i;
101        for(int i=1; i<=m; ++i){
102            scanf("%d %c %d", &A[i], &ch[i], &B[i]);
103            ++A[i];
104            ++B[i];
105            if(ch[i]=='=')
106               Union(A[i], B[i]);
107        }
108        sum=0;
109        for(int i=1; i<=n; ++i)
110           if(f[i]==i)  ++sum;
111        for(int i=1; i<=m; ++i){
112               int fa=getFather(A[i]), fb=getFather(B[i]);//将每一个相等的元素集合看成一个点,这个点的代表就是其父亲节点
113            if(ch[i]=='<'){
114                vx[fa].push_back(fb);
115                ++in[fb];
116            }
117            else if(ch[i]=='>'){
118                vx[fb].push_back(fa);
119                ++in[fa];
120            }
121        }
122
123        conflict=uncertain=0;
124        topoSort();
125        if(conflict)
126           cout<<"CONFLICT"<<endl;
127        else if(uncertain)
128              cout<<"UNCERTAIN"<<endl;
129        else cout<<"OK"<<endl;
130        for(int i=1; i<=n; ++i)
131           vx[i].clear();
132
133        memset(rank, 0, sizeof(int)*(n+1));
134        memset(in, 0, sizeof(int)*(n+1));
135        while(!ss.empty())
136           ss.pop();
137     }
138 }

转载于:https://www.cnblogs.com/hujunzheng/p/3901530.html

hdu 1811Rank of Tetris (并查集 + 拓扑排序)相关推荐

  1. hdu 1811 Rank of Tetris (并查集+拓扑排序)

    Problem - 1811 感觉这题的并查集以及拓扑排序并不难,但是做题的时候必须理解到矛盾(CONFLICT)与不确定(UNCERTAIN)直接的优先关系. 做这题的时候,构图什么的很简单,就是没 ...

  2. HDU - 1811 Rank of Tetris 并查集 + 拓扑序 +me

    link 题意: 首先看到排名自然想到拓扑序,但是存在等于的情况,这就启发我们把等于的情况缩成一个点,让后在缩点后的图中进行拓扑即可. 对于不合法的情况当然是拓扑序没有遍历到应该遍历的点,所以只需要检 ...

  3. HDU——1272小希的迷宫(并查集+拓扑排序)

    小希的迷宫 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  4. hdu5222 Exploration【并查集+拓扑排序】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5222 题意:有一个探险家,探险一个地方,这个地方有n个洞穴,有若干条边,有的边是有向边,有的是无向边, ...

  5. Mr. Kitayuta‘s Technology CodeForces - 505D(并查集+拓扑排序或dfs找环) 题解

    题目  Shuseki Kingdom is the world's leading nation for innovation and technology. There are n cities ...

  6. 家谱树 (并查集拓扑排序)

    目录 拓扑排序 Kahn. 最后附上Kahn的代码: 链式前向星做法: 其次是我用Kahn做的家谱树的代码(矩阵): 其次是我用Kahn做的家谱树的代码(链式前向星): [题目描述] 有个人的家族很大 ...

  7. HDU 2473 Junk-Mail Filter(并查集的删除操作)

    题目地址:HDU 2473 这题曾经碰到过,没做出来. .如今又做了做,还是没做出来. ... 这题涉及到并查集的删除操作.想到了设一个虚节点,可是我把虚节点设为了要删除的点的父节点.一直是栈溢出,目 ...

  8. hdu 3018 图 欧拉回路 并查集

    http://acm.hdu.edu.cn/showproblem.php?pid=3018 题意  --许多蚂蚁 遍历一个图 每一条边只能走一次  问至少要把这些蚂蚁分为几群 说白了就是 至少几笔可 ...

  9. HDU 4775 Infinite Go 并查集

    题目链接:Infinite Go Infinite Go Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K ( ...

最新文章

  1. 手低眼高 初学者学习Hibernate的方法
  2. 是啥意思_227大团结是什么梗啥意思 微博227大团结事件始末介绍
  3. 动态规划 dp01 西瓜分堆问题 c代码
  4. 3-1 Point类的构造函数_JAVA
  5. 模块式开发 java_Java9系列第8篇-Module模块化编程
  6. bootcmd和bootargs
  7. Android之TextView属性详解
  8. MFC工作笔记0005---::在vc++中是什么意思
  9. 实战 | 对抗外部威胁防护和勒索病毒,大厂怎么做?
  10. RS232串口转USB驱动无法正确识别
  11. 联想System x服务器主要硬件Windows Server驱动下载
  12. 东大22春《马克思主义基本原理X》在线平时作业2_100分百分非答案
  13. bugku(Crypto)---ook
  14. 1.React 简介
  15. 淘宝双11的服务器架构分析(2)
  16. (附代码)数独大作业【读取数独,解数独,生成唯一解数独(随机,特定形状,不同难度生成),玩数独】
  17. String字符串的相关语法及JPI
  18. A7 ~ A11处理器(iphone5s~iphoneX) 14.0 ~ 14.8.1免越狱安装Trollstore教程
  19. CSAPP LAB Binary bombs实验报告
  20. 第十届ACM山东省赛总结

热门文章

  1. dataframe 如何选中某列的一行_PySpark和SparkSQL基础:如何利用Python编程执行Spark(附代码)
  2. tomcat jsvc java_opts_Tomcat 学习笔记(2) - 使用 jsvc 启动tomcat
  3. Centos/Red Hat6.8 安装、配置、启动Gitlab (内网环境)
  4. PL/SQL Developer 13.0设置中文
  5. 搭建主从数据库出现的错误 error connecting to master ‘slave@172.17.0.2:3306‘ - retry-time: 30 retries: 1
  6. Navicat连接mysql8.0.1版本出现1251--Client
  7. SpringBoot 整合 Shiro Thymeleaf Mysql 动态授权
  8. 怎样修改老旧commit的message信息?
  9. 1450. 在既定时间做作业的学生人数
  10. system.argumentnullexception值不能为null_MySQL NULL 值如何处理?