博客
关于我
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 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
MySQL 加锁处理分析
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 参数 innodb_flush_log_at_trx_commit
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
MySQL 命令和内置函数
查看>>
MySQL 和 PostgreSQL,我到底选择哪个?
查看>>
mysql 四种存储引擎
查看>>
MySQL 在并发场景下的问题及解决思路
查看>>
MySQL 在控制台插入数据时,中文乱码问题的解决
查看>>
MySQL 基础架构
查看>>
MySQL 基础模块的面试题总结
查看>>
MySQL 处理插入重主键唯一键重复值办法
查看>>
MySQL 备份 Xtrabackup
查看>>
mysql 复杂查询_mysql中复杂查询
查看>>
mYSQL 外键约束
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>