博客
关于我
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为什么不建议使用delete删除数据?
查看>>
MySQL主从、环境搭建、主从配制
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>
MySQL主从同步相关-主从多久的延迟?
查看>>
mysql主从同步配置方法和原理
查看>>
mysql主从复制 master和slave配置的参数大全
查看>>
MySQL主从复制几个重要的启动选项
查看>>
MySQL主从复制及排错
查看>>
mysql主从复制及故障修复
查看>>
MySQL主从复制的原理和实践操作
查看>>
webpack loader配置全流程详解
查看>>
mysql主从复制,读写分离,半同步复制实现
查看>>
MySQL主从失败 错误Got fatal error 1236解决方法
查看>>
MySQL主从架构与读写分离实战
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
mysql主从配置
查看>>
MySQL之2003-Can‘t connect to MySQL server on ‘localhost‘(10038)的解决办法
查看>>
MySQL之CRUD
查看>>
MySQL之DML
查看>>