hdu 1811拓扑排序+并查集(容器实现)

原创 2013年12月03日 17:06:05

http://www.cnblogs.com/newpanderking/archive/2012/10/18/2729566.html

#include<stdio.h>

#include<iostream>
#include<vector>
#include<queue>
using namespace std;
const int N=11000;
vector<int>link[N];//容器来是模拟邻接表
int pre[N],a[N],b[N],indegree[N],n,m,sum;
char c[N];
int find(int x) {//路径压缩
if(x!=pre[x])
pre[x]=find(pre[x]);
return pre[x];
}
int Union(int x,int y) {//合并
int f1=find(x);
int f2=find(y);
if(f1==f2)
return 0;
pre[f1]=f2;
return 1;
}
void bfs() {
       queue<int>q;
  int i,flag;
  for(i=0;i<n;i++) {
  if(find(i)==i&&indegree[i]==0)//将所有第一名的代表放进队列
  q.push(i);
  }   flag=0;
  while(!q.empty()) {//队列实现拓扑排序
  int cur=q.front();
  if(q.size()>1)flag=1;//信息已经不完整了,但是还有可能含有冲突
  q.pop();////和上面的q.size()的判断的顺序不能交换
  for(i=0;i<link[cur].size();i++)
  if(--indegree[link[cur][i]]==0)
  q.push(link[cur][i]);
  sum--;
  }
  if(sum>0)//冲突优先
  printf("CONFLICT\n");
  else
  if(flag==1)//没有冲突了看信息是否完整
  printf("UNCERTAIN\n");
  else
  printf("OK\n");
}
int main() {
int i,f1,f2;
while(scanf("%d%d",&n,&m)!=EOF) {
for(i=0;i<n;i++) {//初始化
link[i].clear();
pre[i]=i;
}
sum=n;
for(i=0;i<m;i++) {
scanf("%d %c%d",&a[i],&c[i],&b[i]);
if(c[i]=='=') 
if(Union(a[i],b[i]))
sum--;
}
memset(indegree,0,sizeof(indegree));//入度
for(i=0;i<m;i++)
if(c[i]!='=') {
f1=find(a[i]);
f2=find(b[i]);
if(c[i]=='>') {
link[f1].push_back(f2);
indegree[f2]++;
}
else {
link[f2].push_back(f1);
indegree[f1]++;
}
}
bfs();
}
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...

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

这道题麻烦的就是有两个数相等的情况出现 我们使用并查集,将相等的并在一起 再用拓扑排序 将入度为0的点push进去 1.队列里面如果有>=2的点,那么代表这信息不完全不能判断 2.如果入队的...

hdu 1811 拓扑排序+并查集

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) ...

HDU1811 并查集+拓扑排序

http://acm.hdu.edu.cn/showproblem.php?pid=1811  这题非常经典,花了一个下午才攻克.加强自己的基础吧. 利用并查集将 '='等号两边的数字并入到一个同...

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/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

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

题目链接:[HDU 1811]Rank of Tetris[拓扑排序][并查集] 题意分析: 给出的关系中是否存在矛盾,是否无法确定关系?两者都有,输出"矛盾"即可。 解题思路: 排名大小关系...

hdu 1811(拓扑排序+并查集)

解题思路: 拓扑排序的两个性质: ①如果一次入队入度为零的点大于1则说明拓扑排序序列不唯一 ②如果排序的总个数小于给定的个数,则说明存在回路 可以先把"="的两个数用并查集放在...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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