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条边构成,那么这些边都是可以的. 这 ...
随机推荐
- MyBatis + MySQL返回插入成功后的主键id
这是最近在实现perfect-ssm中的一个功能时碰到的一个小问题,觉得需要记录一下,向MySQL数据库中插入一条记录后,需要获取此条记录的id值,以生成对应的key值存入到redis中,id为自增i ...
- 快速导入导出Oracle数据demo(sqlldr、UTL_FILE)
本文演示快速sqlldr导入.UTL_FILE导出Oracle表数据实例 表结构如下,演示数据约112万,可自行准备. create table MemberPointDemo ( MEMBERID ...
- 【内存溢出】Maven编译时内存溢出的问题解决方式
原文地址:https://www.cnblogs.com/sunny3096/p/7524635.html 编译源码时报出java.lang.OutOfMemoryError: Java heap s ...
- 设计模式之单例模式(C#)
本文来自于本人个人微信公众号,欢迎关注本人微信公众号,二维码附在文章末尾~~~ 一直都特别羡慕能写文章的人,但是由于本人比较懒再加上写文章功底实在是just so so,所以就一搁再搁,最近突然觉得自 ...
- B-Tree 和 B+Tree
B-Tree和B+Tree 本文来自 Hubery_James 的CSDN 博客 ,全文地址请点击:原文地址-干货满满 B+树索引是B+树在数据库中的一种实现,是最常见也是数据库中使用最为频繁的一种索 ...
- openstack-KVM-vCPU
一.KVM基础功能 (1)支持 硬件支持 VT-x VT-d 系统支持 kernel > 3.5 (2)计算机系统的子系统 CPU 处理器 Memory 内存 Storage 存储 Networ ...
- 03-Linux的shell命令 .doc
快捷键 基本操作和命令 Cd转换文件夹 以/开头的是绝对路径 没有/相对路径 ../代表上一级目录 Tab补充 Ctrl+R 查找历史输入过的命令 箭头上也代表能够查询以往输入的命令 Ctrl+C 终 ...
- 多线程系列之七:Read-Write Lock模式
一,Read-Write Lock模式 在Read-Write Lock模式中,读取操作和写入操作是分开考虑的.在执行读取操作之前,线程必须获取用于读取的锁.在执行写入操作之前,线程必须获取用于写入的 ...
- 1 Expression of Possiblity
Expression of possibility Probably Perhaps There's a change(that) It's very likly(that) It's pos ...
- 工作效率提升之Eclipse篇(1):干掉烦人的xml文件的validation
每次启动maven项目,都会有一堆烦人的xml文件的validation,一旦网络较慢,项目重新启动的时候,这些多余的验证纯属浪费时间. Eclipse上取消validation的方法: 1.菜单[W ...