BZOJ5203 [NEERC2017 Northern] Grand Test 【dfs树】【构造】
题目分析:
首先观察可知这是一个无向图,那么我们构建出它的dfs树。由于无向图的性质我们可以知道它的dfs树只有返祖边。考虑下面这样一个结论。
结论:若一个点的子树中(包含自己)有两个点有到它祖先的返祖边(不包括到它自己),
首先我们证明S和T肯定在DFS树中是祖先关系,接着证明到T至少有一条返祖边,那么这个结论就是显然的了。
代码:
#include<bits/stdc++.h>
using namespace std; const int maxn = ; int n,m;
vector <int>g[maxn]; int up[maxn],dep[maxn],wh[maxn],fa[maxn];
int flag, from, to; void read(){
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) g[i].clear();
for(int i=;i<=m;i++){
int u,v; scanf("%d%d",&u,&v);
g[u].push_back(v); g[v].push_back(u);
}
} int r1[maxn],num1;
int r2[maxn],num2;
int r3[maxn],num3;
int md;
stack <int> s;
void print(int now){
int pla = now;
while(dep[pla] != to) r1[++num1] = pla,pla = fa[pla];
r1[++num1] = pla; pla = md;
while(dep[pla] != dep[now]) s.push(pla),pla = fa[pla];
s.push(pla);
while(!s.empty()){r2[++num2] = s.top();s.pop();}
r2[++num2] = r1[num1]; pla = wh[now];
while(dep[pla] != dep[now]) s.push(pla),pla = fa[pla];
s.push(pla);
while(!s.empty()){r3[++num3] = s.top();s.pop();}
pla = r1[num1];
while(dep[pla] != up[now]) s.push(pla),pla = fa[pla];
s.push(pla);
while(!s.empty()){r3[++num3] = s.top();s.pop();} printf("%d %d\n",r1[],r1[num1]);
printf("%d ",num1);for(int i=;i<=num1;i++) printf("%d ",r1[i]);
puts("");
printf("%d ",num2);for(int i=;i<=num2;i++) printf("%d ",r2[i]);
puts("");
printf("%d ",num3);for(int i=;i<=num3;i++) printf("%d ",r3[i]);
puts("");flag = ;
} void dfs(int now,int dp){
dep[now] = dp;
for(int i=;i<g[now].size();i++){
int nxt = g[now][i];
if(fa[now] == nxt) continue;
if(flag) break;
if(dep[nxt] == ){
fa[nxt] = now;
dfs(nxt,dp+); if(flag) break;
if(up[nxt] >= dep[now]) continue;
if(up[now] >= ) up[now] = up[nxt],wh[now] = wh[nxt];
else{
if(up[now] <= up[nxt]){
from = now; to = up[nxt];md = wh[nxt];
}else {
from = now; to = up[now];up[now] = up[nxt];
md = wh[now];wh[now]= wh[nxt];
}
print(from);
}
}else{
if(dep[nxt] > dep[now]) continue;
if(up[now] >= ) up[now] = dep[nxt],wh[now] = now;
else{
if(up[now] <= dep[nxt]){
from = now; to = dep[nxt];md = now;
}else {
from = now; to = up[now];up[now] = dep[nxt];
md = wh[now];wh[now] = now;
}
print(from);
}
}
}
} void work(){
flag = ; from = ; to = ; num1 = num2 = num3 = ;
for(int i=;i<=n;i++) wh[i] = ,fa[i] = ,dep[i] = ,up[i] = 1e9;
for(int i=;i<=n;i++) if(!dep[i]) dfs(i,);
if(!flag){puts("-1");}
} int main(){
int cas; scanf("%d",&cas);
while(cas--){
read();
work();
}
return ;
}
BZOJ5203 [NEERC2017 Northern] Grand Test 【dfs树】【构造】的更多相关文章
- 7.9 NOI模拟赛 A.图 构造 dfs树 二分图
啥都想不出来的我是不是废了/dk 这道题考的主要是构造 而我想的主要是乱搞. 一个很假很假的做法:直接暴力4种颜色染色 我也不知道对不对.. 不过成功的话一定是对的. 然后考虑奇环的问题 一个很假很假 ...
- dfs树
dfs树是解决图中带环的利器. 前天CF的F题就是dfs树,但是当时我没有认真思考 觉着找到一个环过于困难 当时没有想到 也没理解dfs树的意义. 对于一张无向图求出一个dfs树 这个树有两种边 树边 ...
- zstu.4191: 无向图找环(dfs树 + 邻接表)
4191: 无向图找环 Time Limit: 5 Sec Memory Limit: 128 MB Submit: 117 Solved: 34 Description 给你一副无向图,每条边有 ...
- C#在泛型类中,通过表达式树构造lambda表达式
场景 最近对爬虫的数据库架构做调整,需要将数据迁移到MongoDB上去,需要重新实现一个针对MongoDB的Dao泛型类,好吧,动手开工,当实现删除操作的时候问题来了. 我们的删除操作定义如下:voi ...
- lintcode :前序遍历和中序遍历树构造二叉树
解题 前序遍历和中序遍历树构造二叉树 根据前序遍历和中序遍历树构造二叉树. 样例 给出中序遍历:[1,2,3]和前序遍历:[2,1,3]. 返回如下的树: 2 / \ 1 3 注意 你可以假设树中不存 ...
- lintcode: 中序遍历和后序遍历树构造二叉树
题目 中序遍历和后序遍历树构造二叉树 根据中序遍历和后序遍历树构造二叉树 样例 给出树的中序遍历: [1,2,3] 和后序遍历: [1,3,2] 返回如下的树: 2 / \ 1 3 注意 你可 ...
- BZOJ_4238_电压_树上差分+dfs树
BZOJ_4238_电压_树上差分+dfs树 Description 你知道Just Odd Inventions社吗?这个公司的业务是“只不过是奇妙的发明(Just Odd Inventions)” ...
- LOJ2250 [ZJOI2017] 仙人掌【树形DP】【DFS树】
题目分析: 不难注意到仙人掌边可以删掉.在森林中考虑树形DP. 题目中说边不能重复,但我们可以在结束后没覆盖的边覆盖一个重复边,不改变方案数. 接着将所有的边接到当前点,然后每两个方案可以任意拼接.然 ...
- Codeforces962F Simple Cycles Edges 【双连通分量】【dfs树】
题目大意: 给出一个无向图,问有哪些边只属于一个简单环. 题目分析: 如果这道题我们掌握了点双连通分量,那么结论会很显然,找到每个点双,如果一个n个点的点双正好由n条边构成,那么这些边都是可以的. 这 ...
随机推荐
- 数组去重--ES5和ES6
思路:把去重后的数组放到一个空数组中 ES5实现: function uni(arr) { var result = []; for (var i=0;i<arr.length;i++) { i ...
- Dockerfile centos7_tomcat7.0.64_jdk7u80
FROM centos:7 MAINTAINER jiangzhehao WORKDIR /tmp RUN yum -y install net-tools ADD jdk-7u80-linux-x6 ...
- Vue Router 路由实现原理
一.概念 通过改变 URL,在不重新请求页面的情况下,更新页面视图. 二.实现方式 更新视图但不重新请求页面,是前端路由原理的核心之一,目前在浏览器环境中这一功能的实现主要有2种方式: 1.Hash ...
- 求n!中含有某个因子个数的方法
链接 [https://www.cnblogs.com/dolphin0520/archive/2011/04/11/2012891.html]
- A+B大数运算
基础加法大数运算: [https://vjudge.net/problem/HDU-1002] 题目: 输入两个长度不超过1000的整数求出sum. 思路: 由于数字很大不能直接加,用字符串形式输入, ...
- Mysql数据库中的日期相关操作
1.获取当前时间的日期 select now();----------------------------------如:2008-12-29 16:25:46 select curdate();-- ...
- 不能再忽视了!宝宝不肯吃粥的N个原因,你避免了几个?
辅食不懂怎么添加? 宝宝吃饭爱挑食? 营养均衡和多样化的辅食 在这里你都能找到 宝宝辅食微课堂 不能再忽视了!宝宝不肯吃粥的N个原因,你避免了几个? 2017-10-09 09:35 辅食不懂怎么添加 ...
- jabRef里引用的相邻同名作者变横线
用jabRef引用同名作者的文章时,出现了第二个文章的作者变成了横线,在搜了相关资料后,发现作如下修改可避免: 1.在.bib文件中加入开关,并修改默认配置: @IEEEtranBSTCTL{IEEE ...
- 2 Servlet 细节
1 Servlet 配置详解 ① 由于客户端在浏览器只能通过URL访问web服务器的资源,所以Servlet程序若想被外界访问,必须把Servlet 程序映射到一个URL 地址上,这个工作在项目we ...
- [转帖]Linux下fork函数及pthread函数的总结
Linux下fork函数及pthread函数的总结 https://blog.csdn.net/wangdd_199326/article/details/76180514 fork Linux多进程 ...