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

原创 2015年11月17日 17:14:39

这道题麻烦的就是有两个数相等的情况出现

我们使用并查集,将相等的并在一起

再用拓扑排序

将入度为0的点push进去

1.队列里面如果有>=2的点,那么代表这信息不完全不能判断

2.如果入队的次数小于n,那么代表有环,有冲突

/********************************************
Author         :Crystal
Created Time   :
File Name      :
********************************************/
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <climits>
#include <string>
#include <vector>
#include <cmath>
#include <stack>
#include <queue>
#include <set>
#include <map>
#include <sstream>
#include <cctype>
using namespace std;
typedef long long ll;
typedef pair<int ,int> pii;
#define MEM(a,b) memset(a,b,sizeof a)
#define CLR(a) memset(a,0,sizeof a);
const int inf = 0x3f3f3f3f;
const int MOD = 1e9 + 7;
//#define LOCAL
int u[20000];
int v[20000];
char ch[20000][2];
int par[20000];
int cnt[20000];
std::vector<int> g[20000];
int find(int x){
	return x == par[x] ?x : find(par[x]);
}
int main()
{
#ifdef LOCAL
	freopen("in.txt", "r", stdin);
//	freopen("out.txt","w",stdout);
#endif
	int n,m;
	while(cin >>n >>m){
		CLR(cnt);
		int ccnt = 0;
		for(int i=0;i<n;i++){
			g[i].clear();
		}
		for(int i=1;i<=m;i++){
			scanf("%d%s%d",&u[i],ch[i],&v[i]);
		}
		for(int i=0;i<=n;i++)par[i] = i;
		for(int i=1;i<=m;i++){
			if(ch[i][0]=='='){
				int x = find(u[i]);
				int y = find(v[i]);
				if(x!=y)par[x] = y,ccnt++;
			}
		}
		for(int i=1;i<=m;i++){
			if(ch[i][0]!='='){
				int x = find(u[i]);
				int y = find(v[i]);
				if(ch[i][0]=='>'){
					g[x].push_back(y);
					cnt[y]++;
				}
				else{
					g[y].push_back(x);
					cnt[x]++;
				}			
			}
		}
		queue<int> q;
		for(int i=0;i<n;i++){
			if(cnt[i]==0 && i == find(i)){
				q.push(i);
				ccnt++;
			}
		}
		int flag1 = 0;
		int flag2 = 0;
		//cout << q.size() << endl;
		while(!q.empty()){
			if(q.size() > 1){
				flag1 = 1;
			}
			int u = q.front();
			q.pop();
			for(int i=0;i<g[u].size();i++){
				cnt[g[u][i]]--;
				if(cnt[g[u][i]]==0 && g[u][i] == find(g[u][i])){
					q.push(g[u][i]);
					ccnt++;
				}
			}
		}
		//cout <<flag2 << flag1 <<endl;
		if(ccnt < n){
			flag2 = 1;
		}
		if(flag1 && flag2){
			printf("CONFLICT\n");
		}
		else if(flag1){
			printf("UNCERTAIN\n");
		}
		else if(flag2){
			printf("CONFLICT\n");
		}
		else{
			printf("OK\n");
		}
	}
	return 0;
}








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

思路:利用并查集缩点,把相等的点看成一个,然后他们的父亲的号,就相当于他们的新号 #include #include #include #include #include #include #incl...
  • u013167299
  • u013167299
  • 2015年09月02日 16:18
  • 259

【并查集+拓扑排序】【HDU1811】【Rank of Tetris】

题意:给你3种关系 A=B,A>B,A 解 1.读入数据先处理 =号 用并查集的祖先作为代表元素,其他相等点都 等于 跟这个点重叠。 再读入 ‘’ 来建图进行拓扑排序   2.将所有入度为0的点...
  • zy691357966
  • zy691357966
  • 2015年03月31日 21:57
  • 299

【并查集+拓扑排序】HDU1811 Rank of Tetris

若 a与b的关系为等号则关系已经确定,二则可以看成
  • u012749539
  • u012749539
  • 2014年08月15日 15:36
  • 475

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

题意:中文题意,就不多解释。 思路:这题比普通的拓扑排序多了一个相等的关系,而且当拓扑排序的结果不唯一的时候是输出”UNCERTAIN”. 然后这题处理相等的关系,由于是可以传递特性,果断选择并查...
  • yexiaohhjk
  • yexiaohhjk
  • 2016年04月21日 19:11
  • 206

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

题目描述输入N个人(编号从0到N-1),M条信息。每条信息可能有三种情况,分别是"A > B","A = B","A < B",分别表示A的Rating高于B,等于B,小于B。问根据这些信息,能否确定...
  • Wind_Snow421
  • Wind_Snow421
  • 2017年04月14日 21:29
  • 130

hdu1811 Rank of Tetris(拓扑加并查集)

Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • qq_35634181
  • qq_35634181
  • 2016年08月06日 11:27
  • 75

HDU1811 Rank of Tetris 【缩点】+【拓扑排序】

Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • u012846486
  • u012846486
  • 2014年11月24日 21:46
  • 614

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

题意: 给出一些大小关系,问根据这些关系
  • myHelperIsMe
  • myHelperIsMe
  • 2014年09月16日 10:51
  • 398

Rank of Tetris(并查集和拓扑排序)

Problem Description 自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。 为了更好的符合那些爱好者的喜好,Lele又想了一个...
  • sinat_37668729
  • sinat_37668729
  • 2017年06月24日 23:57
  • 131

Rank of Tetris 拓扑排序 并查集

自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。为了更好的符合那些爱好者的喜好,Lele又想了一个新点子:他将制作一个全球Tetris高手排行榜,定...
  • lifelikes
  • lifelikes
  • 2017年07月15日 09:17
  • 109
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:并查集 + 拓扑排序 hdu1811 Rank of Tetris
举报原因:
原因补充:

(最多只允许输入30个字)