HDU-5222 Exploration(拓扑排序)
一、题目链接
http://acm.hdu.edu.cn/showproblem.php?pid=5222
二、题意
给一个无向边+有向边的混合图,其中每条边只能使用一次,问图中是否存在环。
三、思路
1、必备知识点:图中判断是否存在环
- 无向图
- 有向图
- 无向边+有向边的混合图
#pragma comment(linker, "/STACK:102400000,102400000") #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #include<set> #include<vector> #include<queue> using namespace std; #define MAXN 1000100 typedef long long LL; typedef struct{ int par[MAXN], rk[MAXN]; void init(){ ;i < MAXN;++i)par[i] = i, rk[i] = ; } int root(int x){ return x == par[x] ? x : par[x] = root(par[x]); } void unite(int u, int v){ int x = root(u), y = root(v); if(x == y)return; if(rk[x] < rk[y])par[x] = y; else{ par[y] = x; if(rk[x] == rk[y])rk[y]++; } } bool same(int u, int v){ return root(u) == root(v); } }UniFinder; int N, M1, M2; vector<int> g[MAXN]; int deg[MAXN]; template<class T> inline void read(T& x){ char t; bool sign = false; ')); if(t == '-')sign = true, t =getchar(); x = t - '; + t - '; if(sign)x = -x; } priority_queue<int, vector<int>, greater<int> > que; bool topo_sort(){ while(!que.empty())que.pop(); ;i <= N;++i){ )que.push(i); } int rest = N; while(!que.empty()){ int top = que.top(); que.pop(); rest--; , sz = g[top].size();i < sz;++i){ int to = g[top][i]; deg[to]--; )que.push(to); } } ; } UniFinder uf; int main(){ #ifndef ONLINE_JUDGE freopen("input.txt", "r", stdin); #endif int T, u, v; scanf("%d", &T); while(T--){ ;i < MAXN;++i)g[i].clear(); memset(deg, , sizeof(deg)); uf.init(); bool ans = false; scanf("%d%d%d", &N, &M1, &M2); ;i < M1;++i){ read(u), read(v); if(uf.same(u, v))ans = true; uf.unite(u, v); } ;i < M2;++i){ read(u), read(v); u = uf.root(u), v = uf.root(v); if(u == v)ans = true; if(ans)continue; g[u].push_back(v), deg[v]++; } if(ans)puts("YES"); else printf("%s\n", topo_sort() ? "YES" : "NO"); } ; }
HDU-5222 Exploration(拓扑排序)的更多相关文章
- HDU.2647 Reward(拓扑排序 TopSort)
HDU.2647 Reward(拓扑排序 TopSort) 题意分析 裸的拓扑排序 详解请移步 算法学习 拓扑排序(TopSort) 这道题有一点变化是要求计算最后的金钱数.最少金钱值是888,最少的 ...
- HDU 5222 ——Exploration——————【并查集+拓扑排序判有向环】
Exploration Time Limit: 30000/15000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- ACM: hdu 2647 Reward -拓扑排序
hdu 2647 Reward Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Des ...
- HDU 2647 Reward (拓扑排序)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2647 题意是给你n点m条有向边,叶子点(出度为0)上的值为888,父亲点为888+1,依次计算... ...
- hdu 5438 Ponds 拓扑排序
Ponds Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/contests/contest_showproblem ...
- hdu 4857 逃生 拓扑排序+PQ,剥层分析
pid=4857">hdu4857 逃生 题目是求拓扑排序,但不是依照字典序最小输出,而是要使较小的数排在最前面. 一開始的错误思路:给每一个点确定一个优先级(该点所能到达的最小的点) ...
- HDU 1285 经典拓扑排序入门题
确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- HDU 2647 逆向拓扑排序
令每一个员工都有一个自己的等级level[i] , 员工等级越高,那么工资越高,为了使发的钱尽可能少,所以每一级只增加一单位的钱 输入a b表示a等级高于b,那么我们反向添加边,令b—>a那么i ...
- HDU 4917 Permutation 拓扑排序的计数
题意: 一个有n个数的排列,给你一些位置上数字的大小关系.求合法的排列有多少种. 思路: 数字的大小关系可以看做是一条有向边,这样以每个位置当点,就可以把整个排列当做一张有向图.而且题目保证有解,所以 ...
随机推荐
- __all__的作用
https://blog.csdn.net/orangleliu/article/details/49848413
- bzoj2733: [HNOI2012]永无乡 线段树合并
永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到达另一个岛. ...
- openv+contrib配置总结
本文转载于:https://www.cnblogs.com/wjy-lulu/p/6805557.html 开门见山的说:别用opencv3.0,这个版本添加扩展库不怎么好,能不能成功我不敢说,我是试 ...
- 水晶报表VS2010防止出现用户登录问题
1.联合查询,采用视图办法 2.借用如下语句 using CrystalDecisions.CrystalReports.Engine; using CrystalDecisions.Shared; ...
- C#删除图片问题
public Image GetImage(string path) { FileStream fs = new FileStream(path, FileMode.Open, FileAccess. ...
- 尺取法——POJ3061
#include <iostream> //nlogn复杂度的写法 #include <cstdio> #include <algorithm> using nam ...
- ExtJs 6.0+快速入门,ext-bootstrap.js文件的分析,各版本API下载(一)
ExtAPI 下载地址如下,包含各个版本 http://docs.sencha.com/misc/guides/offline_docs.html 1.使用工具HBuilder 2.java 版本 8 ...
- word问题禁止宏
[在此处输入文章标题] 解决Word2010关闭文档时提示:"您正在试图运行的函数包含有宏或需要宏支持的内容" http://www.cnblogs.com/rhxuza1993/ ...
- [ccf 4] 网络延时
网络延时 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机与交换机.交换机与电脑之间使用网络连接.交换机按层级设置,编号为1的交换机为根交换机,层级为 1.他的交换机都连 ...
- linux查看端口对应的程序及pid
linux中查看特定端口对应的进程以及进程的pid可以使用下面指令: lsof -i:port_number 杀死进程的指令是: kill -s 9 pid