博客
关于我
HDU - 1811 Rank of Tetris 并查集 + 拓扑序
阅读量:251 次
发布时间:2019-03-01

本文共 1907 字,大约阅读时间需要 6 分钟。

题意:

在这里插入图片描述
首先看到排名自然想到拓扑序,但是存在等于的情况,这就启发我们把等于的情况缩成一个点,让后在缩点后的图中进行拓扑即可。
对于不合法的情况当然是拓扑序没有遍历到应该遍历的点,所以只需要检查遍历了几个点即可。对于信息不全的情况,那就是对应同一级存在多个点,所以只需要判断队列是否恒为一个元素即可(当然这种说法不严谨)。
最后如果用并查集缩点的话,一定要注意判断 i == find(i) ,因为缩完点之后这个点就是这个集合的代表。

//#pragma GCC optimize(2)#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define X first#define Y second#define L (u<<1)#define R (u<<1|1)#define pb push_back#define mk make_pair#define Mid (tr[u].l+tr[u].r>>1)#define Len(u) (tr[u].r-tr[u].l+1)#define random(a,b) ((a)+rand()%((b)-(a)+1))#define db puts("---")using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;typedef unsigned long long ULL;typedef pair
PII;const int N=100010,M=N*2,mod=1e9+7,INF=0x3f3f3f3f;const double eps=1e-6;int n,m;int e[M],ne[M],h[N],idx;int p[N],tot;int d[N];bool st[N];struct Query{ int a,b; char op;}q[N];void add(int a,int b){ e[idx]=b,ne[idx]=h[a],h[a]=idx++;}int find(int x){ return x==p[x]? x:p[x]=find(p[x]);}int topsort(){ int sum=0,s=0; int f1,f2; f1=f2=0; queue
q; for(int i=0;i
1) f1=1; while(q.size()) { int cnt=0; sum++; int u=q.front(); q.pop(); for(int i=h[u];~i;i=ne[i]) { int j=e[i]; if(--d[j]==0) q.push(j),cnt++; } if(cnt>1) f1=1; } if(sum!=s) f2=1; if(f1&&f2) return 2; else if(f2) return 2; else if(f1) return 1; else return 0;}int main(){ // ios::sync_with_stdio(false);// cin.tie(0); while(scanf("%d%d",&n,&m)!=EOF) { idx=0; tot=0; for(int i=0;i
') d[a]++,add(b,a); else d[b]++,add(a,b); } int t=topsort(); if(t==2) puts("CONFLICT"); else if(t==1) puts("UNCERTAIN"); else puts("OK"); } return 0;}/**/

转载地址:http://nslx.baihongyu.com/

你可能感兴趣的文章
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>