并查集 + 拓扑排序 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;
}








相关文章推荐

HDU Problem 1811 Rank of Tetris【拓扑排序+并查集】

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

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

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

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

Rank of Tetris Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • zugofn
  • zugofn
  • 2016年08月06日 10:39
  • 105

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

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

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

Rank of Tetris Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) To...
  • Puyar_
  • Puyar_
  • 2016年07月24日 11:25
  • 147

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

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

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

做法:把等于的用并查集放一起,找出最小的数,也就是入度为零的数。然后开始拓扑,拓扑就是每次把入度为0,也就是剩下点中最小的数拿来,再把它的上一个入度减掉。 如果有点没访问,就是说明有环,说明矛盾。 ...

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

题目链接:Click here~~ 题意: 中文题啊中文题。 解题思路: 此题关键的一点是要意识到排序时,Rating相同的人一定排列在一起,且顺序一定存在。 故可以...
  • dgq8211
  • dgq8211
  • 2012年07月21日 16:00
  • 650

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

问题描述: Problem Description 自从Lele开发了Rating系统,他的Tetris事业更是如虎添翼,不久他遍把这个游戏推向了全球。为了更好的符合那些爱好者的喜好,Lele又想...

[HDU 1811]Rank of Tetris[拓扑排序][并查集]

题目链接:[HDU 1811]Rank of Tetris[拓扑排序][并查集] 题意分析: 给出的关系中是否存在矛盾,是否无法确定关系?两者都有,输出"矛盾"即可。 解题思路: 排名大小关系...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:并查集 + 拓扑排序 hdu1811 Rank of Tetris
举报原因:
原因补充:

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