Rank of Tetris

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

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:  1558 1879 1863 1875 1823 
 
分析:
如果直接拓扑的话,等号的情况很麻烦
一.采用并查集处理=号的情况
把具有等号关系的点聚合成为一个连通分量,且只用该连通分量的根结点替代分量中的所有点
比如A=B=C=D
以后A,B,C,D这四个点就只用A来表示
 
需要注意的地方:
1.必须先处理完所有的等号之后再进行拓扑排序(最后才想到!!!)
2.因为存在等号,我们有把等号处理了,所有我们可以拓扑的点可能不是n个了,而是根结点的个数个
 
2.采用拓扑排序处理>和<的情况
 
ps:
冲突情况:存在环,也就是进入队列的点不等于可以拓扑的点
信息不完全:某时刻队列里面元素个数大于1个,说明图不是连通图
 
 
必须先处理完所有等号的情况才能进行拓扑!!!
wa好多次
 
#include<stdio.h>
#include<iostream>
#include<math.h>
#include<string.h>
#include<set>
#include<map>
#include<list>
#include<queue>
#include<algorithm>
using namespace std;
typedef long long LL;
int mon1[]= {,,,,,,,,,,,,};
int mon2[]= {,,,,,,,,,,,,};
int dir[][]= {{,},{,-},{,},{-,}}; int getval()
{
int ret();
char c;
while((c=getchar())==' '||c=='\n'||c=='\r');
ret=c-'';
while((c=getchar())!=' '&&c!='\n'&&c!='\r')
ret=ret*+c-'';
return ret;
} #define max_v 20005
int pa[max_v];
int rk[max_v];
int indgree[max_v];
int a[max_v],b[max_v];
char o[max_v];
queue<int> q;
vector<int> vv[max_v];
int n,m,cnt;
int fa_num;
void init()
{
for(int i=; i<=n; i++)
pa[i]=i,rk[i]=;
memset(indgree,,sizeof(indgree));
while(!q.empty())
q.pop();
for(int i=; i<=n; i++)
vv[i].clear();
fa_num=;
cnt=;
}
int find_set(int x)
{
if(x!=pa[x])
pa[x]=find_set(pa[x]);
return pa[x];
}
void union_set(int x,int y)
{
x=find_set(x);
y=find_set(y);
if(x==y)
return ;
if(rk[x]>rk[y])
pa[y]=x;
else
{
pa[x]=y;
if(rk[x]==rk[y])
rk[y]++;
}
}
int tpsort()
{
for(int i=; i<=n; i++)
{
if(find_set(i)==i)//拓扑点必须是根结点
{
fa_num++;//计数 根结点
if(indgree[i]==)
q.push(i);
}
}
int temp;
int flag=;
while(!q.empty())
{
if(q.size()>)
flag=;//信息不完全
temp=q.front();
q.pop();
cnt++; for(int i=; i<vv[temp].size(); i++)
{
indgree[find_set(vv[temp][i])]--;
if(indgree[find_set(vv[temp][i])]==)
q.push(find_set(vv[temp][i]));
}
}
if(flag)//不能全拓扑(整个图不是连通的)
return ;
else
return ;
}
int main()
{
int x,y;
char c;
while(~scanf("%d %d",&n,&m))
{
if(n==&&m==)
{
printf("OK\n");
continue;
}
init();
int flag1=;//冲突 1
int flag2=;//信息不完全 1
for(int i=; i<=m; i++)//必须先合并除去=号,不能边除去边拓扑!!!
{
getchar();
scanf("%d %c %d",&a[i],&c,&b[i]);
a[i]++,b[i]++;
o[i]=c;
if(c=='=')
{
union_set(a[i],b[i]);
}
}
for(int i=;i<=m;i++)
{
if(o[i]=='=')
continue;
x=find_set(a[i]);
y=find_set(b[i]);
if(o[i]!='='&&find_set(x)==find_set(y))
{
flag1=;
continue;
}
if(o[i]=='<')
{
int temp=x;
x=y;
y=temp;
}
if(count(vv[y].begin(),vv[y].end(),x)!=)//环的一种情况
{
flag1=;
}
if(count(vv[x].begin(),vv[x].end(),y)==)//预防重边
{
vv[x].push_back(y);
indgree[y]++;
}
}
flag2=tpsort();
if(cnt!=fa_num)//不能全排列拓扑,因为信息不全
flag1=;
if(flag1==&&flag2==)
{
printf("OK\n");
}
else if(flag1==&&flag2==)
{
printf("CONFLICT\n");
}
else if(flag2==&&flag1==)
{
printf("UNCERTAIN\n");
}
else if(flag1==&&flag2==)
{
printf("CONFLICT\n");
}
}
return ;
}
 
 

HDU 1811 Rank of Tetris(并查集+拓扑排序 非常经典)的更多相关文章

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

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  2. hdu1811 Rank of Tetris 并查集+拓扑排序

    #include <stdio.h> #include <string.h> #include <vector> #include <queue> us ...

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

    /* 题意:这些信息可能有三种情况,分别是"A > B","A = B","A < B",分别表示A的Rating高于B,等于B ...

  4. ACM: hdu 1811 Rank of Tetris - 拓扑排序-并查集-离线

    hdu 1811 Rank of Tetris Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & % ...

  5. HDU 1811:Rank of Tetris(并查集+拓扑排序)

    http://acm.hdu.edu.cn/showproblem.php?pid=1811 Rank of Tetris Problem Description   自从Lele开发了Rating系 ...

  6. 并查集+拓扑排序 赛码 1009 Exploration

    题目传送门 /* 题意:无向图和有向图的混合图判环: 官方题解:首先对于所有的无向边,我们使用并查集将两边的点并起来,若一条边未合并之前, 两端的点已经处于同一个集合了,那么说明必定存在可行的环(因为 ...

  7. hdu 1811 Rank of Tetris - 拓扑排序 - 并查集

    自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球. 为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜, ...

  8. HDU 1811 Rank of Tetris(并查集按秩合并+拓扑排序)

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  9. HDU 1811 Rank of Tetris 拓补排序+并查集

    Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) [ ...

随机推荐

  1. HDU3592(差分约束)

    World Exhibition Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. python网络爬虫抓取动态网页并将数据存入数据库MySQL

    简述以下的代码是使用python实现的网络爬虫,抓取动态网页 http://hb.qq.com/baoliao/ .此网页中的最新.精华下面的内容是由JavaScript动态生成的.审查网页元素与网页 ...

  3. CSS画0.5px的线

    今天遇到一个需求,画0.5px的线,查了以下资料,主要以scale方法为主.代码如下: /*0.5px上边框*/ .half_top_border_before:before{ content: &q ...

  4. javascript预编译的过程

    预编译的两种情况 全局: 1.全局 直接是script标签中的代码,不包括函数执行执行前:1.首先生成一个GO(global object)对象,看不到,但是可以模拟出来用来分析2.分析变量声明,变量 ...

  5. dubbo 图片服务器(FastDFS) redis solr ActiveMQ等简单配置使用

    一.dubbo 项目基于soa的架构,表现层和服务层是不同的工程.所以要实现商品列表查询需要两个系统之间进行通信. 1.1如何实现远程通信? 1.Webservice:效率不高基于soap协议.项目中 ...

  6. Glusterfs的常用命令

    1 服务器节点 # gluster peer status                          //查看所有节点信息,显示时不包括本节点 # gluster peer probe   N ...

  7. hihocoder [Offer收割]编程练习赛12 [1495] ---- 矩形分割

    原题链接 矩形分割 算法分析: 解决该题要用到"并查集"的思想. 这里有一篇不错的博客介绍并查集: 并查集(Union-Find)算法介绍 记 int total=N*M,这里会有 ...

  8. 使用CDN做网站的内容加速

    1.什么是CDN: CDN的全称是Content Delivery Network,中文的意思就是内容分发网络,简单的讲通过现有的Internet中增加一层新的网络架构,将网站的内容发布到最接近用户的 ...

  9. Flutter Dart中的异步

    以下内容从官网得到: https://webdev.dartlang.org/articles/performance/event-loop Even-Looper Dart是单线程模型,也就没有了所 ...

  10. Express使用Https服务器

    var fs = require('fs'); var http = require('http'); var https = require('https'); var privateKey = f ...