题目链接: 传送门
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 ...
随机推荐
-
Oracle组合索引与回表
回表 简单来说就是数据库根据索引找到了指定的记录所在行后,还需要根据rowid再次到数据块里取数据的操作. "回表"一般就是指执行计划里显示的"TABLE ACCESS ...
-
SPRING IN ACTION 第4版笔记-第二章-003-以Java形式注入Bean、@Bean的用法
1. package soundsystem; import org.springframework.context.annotation.Bean; import org.springframewo ...
-
利用rowid更新单表
SQL> create table test1(id int,name char(10)); Table created. begin for i in 1 .. 1000000 loop in ...
-
BOOST中如何实现线程安全代码
1 需要include <boost/thread.hpp> 2 背景知识请参考<boost程序库完全开发指南>第12章 3 编绎:g++ -o mthread mthread ...
-
virtual dom的实践
最近基于virtual dom 写了一个小框架-aoy. aoy是一个轻量级的mvvm框架,基于Virtual DOM.虽然现在看起来很单薄,但我做了完善的单元测试,可以放心使用.aoy的原理可以说和 ...
-
前端入门15-JavaScript进阶之原型链
声明 本系列文章内容全部梳理自以下几个来源: <JavaScript权威指南> MDN web docs Github:smyhvae/web Github:goddyZhao/Trans ...
-
如何在mpvue下收集小程序的formId
什么是formId formId是小程序可以向用户发送模板消息的通行证,简单而言,你只有获取到formId,把它交给后台,后台同学才能向用户发送通知消息,而这个通行证的有效期只有七天.这是微信为了防止 ...
-
spring boot 集成Druid
Druid是阿里巴巴开源平台上一个数据库连接池实现,它结合了C3P0.DBCP.PROXOOL等DB池的优点,同时加入了日志监控,可以很好的监控DB池连接和SQL的执行情况,可以说是针对监控而生的DB ...
-
十一、持久层框架(MyBatis)
一.基于注解方式的CRUD 把xml方式的CRUD修改为注解方式 之前在xml中配置,是在<mapper></mapper>标签下写CRUD <mapper namesp ...
-
ld 脚本浅析-LD手册粗糙翻译
本文乃转载, 我在其基础上做了少量修改. 原作者的E-mail是zhanglei@sict.ac.cn. 完成于2005.11.5-2005.11.8 0. Contents 1. 概论2. 基本概念 ...