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

  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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/531774.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ambari mysql jar_从零开始安装 Ambari (3) -- 安装 Ambari

1. 安装yum -y install ambari-server2. ambari server 需要一个数据库存储元数据&#xff0c;默认使用的 Postgres 数据库。默认的用户名和密码是&#xff1a; ambari/bigdata 。但是一般情况下&#xff0c;后面还要安装 hive 和 Ranger&#xff0c;也需要一个存元数据的数据库…

服务器2012系统在dos卸载,Windows系统下彻底删除Windows.old 文件夹的方法

系统是直接硬盘安装的&#xff0c;导致c盘产生了旧系统的文件夹Windows.old&#xff0c;占用很大的磁盘空间&#xff0c;删也删不掉&#xff0c;咋办&#xff1f;不要紧&#xff0c;下面大神来教你神操作&#xff01;&#xff01;&#xff01;1、打开“计算机”&#xff0c;选择…

hdu3635 Dragon Balls(带权并查集)

1 /*2 题意&#xff1a;有N个城市&#xff0c; 每一个城市都有一个龙珠&#xff08;编号与城市的编号相同&#xff09;&#xff0c;有两个操作3 T A ,B 将标号为A龙珠所在城市的所有的龙珠移动到B龙珠所在城市中&#xff01; 4 5 思路&#xff1a;并查集 &#xff…

backupexec mysql_MySQL备份可能遇到的坑

MySQL备份工具&#xff0c;支持各种参数选项&#xff0c;使用不同的选项极有可能影响备份处理过程。本文使用我们常规认为合理的备份参数&#xff0c;测试/验证是否存在容易忽视的坑# 常规备份参数# mysqldumpshell> mysqldump --single-transaction --master-data2 -B repl…

win10虚拟机服务器错误怎么解决方法,虚拟机下安装win10系统后出现升级报错故障的解决方法【图文】...

现在的win10还是很挑系统的&#xff0c;兼容性有待进一步增强。有些在虚拟机环境下安装了win10的小伙伴&#xff0c;升级是很可能报以下错误的&#xff0c;升级你的ESX版本吧&#xff0c;5.5以下升级win10基本都是没戏的。VM workstation11以上是明确支持win10。不能升级win10怎…

hdu1962Corporative Network带权回路

1 /*2 有N个企业&#xff0c;每个企业想要实现通信&#xff0c;要用线路来连接&#xff0c;线路的长度为abs(a-b)%1000;3 如果企业a 链接到了企业b 那么b就是the center of the serving!4 然后有两种操作&#xff1a;5 E a &#xff1a; 输出企业a到serving ce…

mysql客户端修改sqlmode_MySQL修改sql_mode

一 ERR 1067引发的血案今天在Navicat中运行sql语句创建数据表出现了错误Err 1067。而这条语句在有些同事的mysql上是正确的&#xff0c;但是在有些人那里就报错。QQ截图20170811143551.png原因竟然是timestamp的默认值不正确。查阅资料得知&#xff0c;mysql5.7版本中有了一个S…

零基础mysql项目实例_MySQL-零基础开发

1.终端下连接mysql服务mysql -uroot -p回车后输入设定的密码即可。进去后每条命令结尾要带分号&#xff1b;退出命令exit单行注释有两种&#xff1a;#  或 --空格。多行注释/*  */2.基本命令集合针对数据库&#xff1a;use sys;  show databases;查看当前操作的数据库&a…

hdu2066一个人的旅行(多源点多汇点的最短路径问题)

&#xff0f;&#xff0a;思路&#xff1a;多源点&#xff0c;多会点的最短路径&#xff01;将最小号&#xff0d;&#xff11;的节点但最源点&#xff0c;将最大号&#xff0b;&#xff11;的点当作汇点&#xff01;将问题转变成从一个源点到一个汇点的最短路径的问题&#xf…

php设置mysql 编码_php怎么设置mysql编码?

在php中&#xff0c;可以使用mysql_query()函数来设置mysql编码&#xff0c;语法“mysql_query(SET NAMES 编码方式);”&#xff1b;mysql_query()函数需要放置在mysql_connect()语句之后。在php中&#xff0c;可以使用mysql_query()函数来设置mysql编码。在PHP连接数据库的时候…

nyoj 925 国王的烦恼(最小生成树)

1 /*2 题意&#xff1a;N个城市中每两个城市有多条路径连接&#xff0c;可是因为路径存在的天数是有限的&#xff01;以为某条路经不存在了3 导致N个城市不能连通了&#xff0c;那么村名们就会抗议&#xff01;问一共会有多少次抗议&#xff01;4 5 思路&#…

golang 切片 接口_Go编程模式:切片,接口,时间和性能

在本篇文章中&#xff0c;我会对 Go 语言编程模式的一些基本技术和要点&#xff0c;这样可以让你更容易掌握 Go 语言编程。其中&#xff0c;主要包括&#xff0c;数组切片的一些小坑&#xff0c;还有接口编程&#xff0c;以及时间和程序运行性能相关的话题。本文是全系列中第 1…

poj 3352Road Construction(无向双连通分量的分解)

1 /*2 题意&#xff1a;给定一个连通的无向图G&#xff0c;至少要添加几条边&#xff0c;才能使其变为强连通图&#xff08;指的是边强联通&#xff09;。 3 思路&#xff1a;利用tarjan算法找出所有的双联通分量&#xff01;然后根据low[]值的不同将双联通分量4 进行…

jsp中去掉超链接下划线吗_网页中如何去掉超链接的下划线

展开全部a:link {text-decoration: none;}a:visited {text-decoration: none;color: #6B6C70;}其中的text-decoration: none;是消除下划线例如&#xff1a;只需加入一段代码32313133353236313431303231363533e59b9ee7ad9431333337393534&#xff1a;td,body { font-size: 9pt}a…

POJ 2312Battle City(BFS-priority_queue 或者是建图spfa)

1 /*2 bfs搜索&#xff01;要注意的是点与点的权值是不一样的哦&#xff01;3 空地到空地的步数是1&#xff0c; 空地到墙的步数是2&#xff08;轰一炮移过去&#xff09;4 所以用到优先队列进行对当前节点步数的更新&#xff01; 5 */6 #include<iostream>7 #…

linux训练python出现killed_Linux 查看进程被杀死的详情

运行写的不太完善的爬虫程序, 未限制任务队列大小, 再加上本子配置不高, 爬取网站到第3层大半时, 内存不足了...进程运行太猛, 导致系统 out of memory, 那么此进程被系统的oom killer杀死.此时终端显示 "Killed" 或 "已杀死".查看相关信息的命令:dmesg | …

mysql 123456_MySQL字符串中抽取数值的方法 select -(-'123456@163.com'); 很牛逼

MySQL的字符串函数非常多&#xff0c;以至于有时候我不知道该如何灵活的使用这些函数。字符串基本信息函数 collation convert&#xff0c;char_length等加密函数 password(x)&#xff0c;encode, aes_encrypt字符串连接函数 concat(x1,x2,….)修剪函数 trim,ltrim,…

ZZUOJ 1199 大小关系(拓扑排序,两种方法_判断入度和dfs回路判断)

1 /*2 这道题如果按照度为0的节点来判断的时候,将度为0的节点和其相连的节点&#xff08;度数并减去1&#xff09; 3 从图中去掉&#xff0c;如果度为0的节点的个数为0个但是图中的节点没有都去掉的 时候那么说明4 出现了回路!用这种方法必须将重边去除掉&#xff01; …

matlab画图plot设置字体_R语言科研画图字体格式设置

作者&#xff1a;黄天元&#xff0c;复旦大学博士在读&#xff0c;热爱数据科学与开源工具&#xff08;R&#xff09;&#xff0c;致力于利用数据科学迅速积累行业经验优势和科学知识发现&#xff0c;涉猎内容包括但不限于信息计量、机器学习、数据可视化、应用统计建模、知识图…

hdu3339 In Action(Dijkstra+01背包)

1 /*2 题意&#xff1a;有 n 个站点&#xff08;编号1...n&#xff09;&#xff0c;每一个站点都有一个能量值&#xff0c;为了不让这些能量值连接起来&#xff0c;要用 3 坦克占领这个站点&#xff01;已知站点的 之间的距离&#xff0c;每个坦克从0点出发到某一个站点&…