HDU 1811 Rank of Tetris(拓扑排序+并查集)
题目链接: 传送门
Rank of Tetris
Time Limit: 1000MS Memory Limit: 32768 K
Description
自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜,定时更新,名堂要比福布斯富豪榜还响。关于如何排名,这个不用说都知道是根据Rating从高到低来排,如果两个人具有相同的Rating,那就按这几个人的RP从高到低来排。终于,Lele要开始行动了,对N个人进行排名。为了方便起见,每个人都已经被编号,分别从0到N-1,并且编号越大,RP就越高。同时Lele从狗仔队里取得一些(M个)关于Rating的信息。这些信息可能有三种情况,分别是"A > B","A = B","A
Input
本题目包含多组测试,请处理到文件结束。每组测试第一行包含两个整数N,M(0
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
解题思路:
难点在于" = "的情况,此时把相等的数字用一个集合的根节点表示,如果一次入队入度为零的点大于1则说明拓扑排序序列不唯一,用分叉树去理解的话,就是同一层有多个节点,此时就是信息不完全产生多解,如果需要排序的个数小于所给定的数,那么就是存在环,也就是有冲突。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
using namespace std;
const int MAX = 10005;
vector<int>edge[MAX];
int A[MAX],B[MAX],Indegree[MAX],root[MAX];
char str[MAX];
int N,M,sum;
void init()
{
memset(A,0,sizeof(A));
memset(B,0,sizeof(B));
memset(Indegree,0,sizeof(Indegree));
memset(root,0,sizeof(root));
for (int i = 0;i < N;i++)
{
root[i] = i;
edge[i].clear();
}
}
int find(int x)
{
if (root[x] == x)
return x;
else
{
return root[x] = find(root[x]);
}
}
int unite(int x,int y)
{
x = find(x);
y = find(y);
if (x == y)
return 0;
root[y] = x;
return 1;
}
void Topsort()
{
bool uncertain = false;
queue<int>que;
for(int i = 0;i < N;i++)
{
if (Indegree[i] == 0 && find(i) == i) //find(i) = i;避免同一个点被多次使用
{
que.push(i);
}
}
while (!que.empty())
{
if (que.size() > 1) uncertain = true;
int val = que.front();
que.pop();
sum--;
for (int i = 0;i < edge[val].size();i++)
{
if (--Indegree[edge[val][i]] == 0)
{
que.push(edge[val][i]);
}
}
}
if (sum > 0) //存在环
{
printf("CONFLICT\n");
}
else if (uncertain)
{
printf("UNCERTAIN\n");
}
else
{
printf("OK\n");
}
}
int main()
{
while (~scanf("%d%d",&N,&M))
{
int x,y;
sum = N;
init();
for (int i = 0;i < M;i++)
{
scanf("%d %c %d",&A[i],&str[i],&B[i]);
if (str[i] == '=')
{
if (unite(A[i],B[i]))
sum--;
}
}
for (int i = 0;i < M;i++)
{
if (str[i] == '=') continue;
x = find(A[i]);
y = find(B[i]);
if (str[i] == '>')
{
edge[x].push_back(y);
Indegree[y]++;
}
else if (str[i] == '<')
{
edge[y].push_back(x);
Indegree[x]++;
}
}
Topsort();
}
return 0;
}
HDU 1811 Rank of Tetris(拓扑排序+并查集)的更多相关文章
- ACM: hdu 1811 Rank of Tetris - 拓扑排序-并查集-离线
hdu 1811 Rank of Tetris Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & % ...
- hdu 1811 Rank of Tetris - 拓扑排序 - 并查集
自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球. 为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜, ...
- hdu1811 Rank of Tetris 拓扑排序+并查集
这道题是拓扑排序和并查集的综合运用. 由于排行榜是一种从高到低的排序.所以在拓扑排序的时候,如果有一次加入的入度为零的点数大于1,就有变得不确定了(UNCERTAIN). 由于只有一棵树,当树的数量大 ...
- Rank of Tetris 拓扑排序+并查集
Problem Description 自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球. 为了更好的符合那些爱好者的喜好,Lele又想了一个新点子: ...
- hdu 1811 Rank of Tetris (拓扑 & 并查集)
Rank of Tetris Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- HDU 1811 拓扑排序 并查集
有n个成绩,给出m个分数间的相对大小关系,问是否合法,矛盾,不完全,其中即矛盾即不完全输出矛盾的. 相对大小的关系可以看成是一个指向的条件,如此一来很容易想到拓扑模型进行拓扑排序,每次检查当前入度为0 ...
- HDU 1811 Rank of Tetris(并查集按秩合并+拓扑排序)
Rank of Tetris Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- HDU 1811 Rank of Tetris(并查集+拓扑排序 非常经典)
Rank of Tetris Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- hdu 1811 Rank of Tetris (并查集+拓扑排序)
Rank of Tetris Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
随机推荐
- 常用 redis 命令(for php)
Redis 主要能存储 5 种数据结构,分别是 strings,hashes,lists,sets 以及 sorted sets. 新建一个 redis 数据库 $redis = new Redis( ...
- 对《重建中国.NET生态系统》评论贴的总结
Neuzilla官方微信公众号:搜 架构师联盟 或 neuzilla,也可以扫下面二维码 在看了<重建中国.NET生态系统>的各种哭爹喊娘骂街的评论之后,我觉得哦,淫才确实很多,但是么真正 ...
- 用canvas 实现个图片三角化(LOW POLY)效果
之前无意中看到Ovilia 用threejs做了个LOW POLY,也就是图片平面三角化的效果,觉得很惊艳,然后就自己花了点时间尝试了一下. 我是没怎么用过threejs,所以就直接用canvas的2 ...
- Android开发自学笔记—1.1(番外)AndroidStudio常用功能介绍
一.界面区介绍 1.项目组织结构区,用于浏览项目文件,默认Project以Android组织方式展示. 2.设计区,默认在打开布局文件时为设计模式,可直接拖动控件到界面上实现所见即所得,下方的Desi ...
- MD5加密与验证
package com.study; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException ...
- Collection中list集合的应用常见的方法
集合 : 用存放对象的容器(集合) Collection : 跟接口 : 单列集合 ---> List :有序的 ,元素是可以重复的. ---> ...
- chrome编辑DOM
来源于:https://developers.google.com/web/tools/chrome-devtools/inspect-styles/edit-dom The DOM tree vie ...
- Ceph: validate that the RBD cache is active
Ceph: validate that the RBD cache is active Quick and simple test to validate if the RBD cache is en ...
- TouchSlop与VelocityTracker认识
TouchSlop是处理触摸事件中的一个常量,被系统认为滑动和点击事件的临界点.理 解这个touchSlop是一个滑动距离值的常量,也就是说当我们手触摸在屏幕上滑动时,如果滑动距离没有超过touchS ...
- OkHttp:Java 平台上的新一代 HTTP 客户端
OkHttp 简介 OkHttp 库的设计和实现的首要目标是高效.这也是选择 OkHttp 的重要理由之一.OkHttp 提供了对最新的 HTTP 协议版本 HTTP/2 和 SPDY 的支持,这使得 ...