[jzoj]3506.【NOIP2013模拟11.4A组】善良的精灵(fairy)(深度优先生成树)
Link
https://jzoj.net/senior/#main/show/3506
Description
从前有一个善良的精灵。
一天,一个年轻人B找到她并请他预言他的未来。这个精灵透过他的水晶球看到这个年轻人将要遇见一个非常美丽的公主并要娶她。。精灵在一张纸上画了N个点并用一些线段将他们连起来,每条线段两端连着不同的点。画完了之后,精灵让年轻人去除一条线段。然后精灵尝试将每个点用红色或者蓝色进行染色,同时使得那里没有一条线段的两端是相同的颜色。如果精灵能够成功染色,这个预言就能成真。
年轻人想要遇见那位公主,因此他请求你去帮助他,找到所有的删除之后能对图进行成功染色的线段。
Solution
0~99分
显然爆搜。
100分
题目大意就是“给你一个无向图,让你删去一条边,使得原图无奇环”
既然考虑到环的奇偶性,自然就得考虑到其个数。按照惯例,绘制一个深度优先生成树(DFS树)
怎么绘制呢?
选择一个点为根,按照DFS的顺序,连出一棵树。当一个点连向一个深度小与它的点,显然,就构成了一个环。
我们称这条边为返祖边,这个环的大小就是两点深度差+1。
然后在树上弄一个类似差分约束的思路,来求出当前边被多少个奇数,偶数环所包括。

对于一条边
(1)全图无环或者只有一个偶环,当前边可以删
(2)如果不符合(1),可以删当前边,仅当当前边被这个图所有奇数环覆盖,且不被一个偶数环包括。
引理1易证
引理2:如果奇数和偶数环在一起,删完后一定不满足。如果不包括所有奇数环,那么在不被当前边包括的奇数环就不满足。
Code
{$inline on}
var
n,m,i,x,y,tot,tot1,papa:longint;
w:array[..] of longint;
dis:array[..] of boolean;
data:array[..] of longint;
pre,tov,last:array[..] of longint;
pre1,tov1,cos1,last1:array[..] of longint;
ji,ou,numj,numo:array[..] of longint;
procedure insert(x,y:longint); inline;
begin
inc(tot);
tov[tot]:=y;
pre[tot]:=last[x];
last[x]:=tot;
end;
procedure insert1(x,y,z:longint); inline;
begin
inc(tot1);
tov1[tot1]:=y;
cos1[tot1]:=z;
pre1[tot1]:=last1[x];
last1[x]:=tot1;
end;
procedure dg(x,q,shen:longint); inline;
var
k:longint;
begin
dis[x]:=true;
w[x]:=shen;
k:=last[x];
while k<> do
begin
if tov[k]<>q then
begin
if not dis[tov[k]] then
begin
insert1(x,tov[k],(k+) shr );
dg(tov[k],x,shen+);
end
else
if w[tov[k]]<w[x] then
begin
if odd(w[tov[k]]-w[x]+) then
begin
inc(ji[x]);
dec(ji[tov[k]]);
numj[(k+) shr ]:=;
inc(papa);
end
else
begin
inc(ou[x]);
dec(ou[tov[k]]);
numo[(k+) shr ]:=;
end;
end;
end;
k:=pre[k];
end;
end;
procedure find(x:longint); inline;
var
k:longint;
begin
k:=last1[x];
while k<> do
begin
find(tov1[k]);
numj[cos1[k]]:=ji[tov1[k]];
numo[cos1[k]]:=ou[tov1[k]];
inc(ji[x],numj[cos1[k]]);
inc(ou[x],numo[cos1[k]]);
k:=pre1[k];
end;
end;
begin
assign(input,'fairy.in');reset(input);
assign(output,'fairy.out');rewrite(output);
readln(n,m);
for i:= to m do
begin
readln(x,y);
insert(x,y);
insert(y,x);
end;
for i:= to n do
if not dis[i] then
begin
dg(i,,);
find(i);
end;
for i:= to m do
if ((numj[i]=papa) and (numo[i]=)) or (papa=) then
begin
inc(data[]);
data[data[]]:=i;
end;
writeln(data[]);
for i:= to data[] do
write(data[i],' ');
end.
[jzoj]3506.【NOIP2013模拟11.4A组】善良的精灵(fairy)(深度优先生成树)的更多相关文章
- JZOJ 3505. 【NOIP2013模拟11.4A组】积木(brick)
3505. [NOIP2013模拟11.4A组]积木(brick) (File IO): input:brick.in output:brick.out Time Limits: 1000 ms Me ...
- JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C
3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...
- JZOJ 3508. 【NOIP2013模拟11.5B组】好元素
3508. [NOIP2013模拟11.5B组]好元素(good) (File IO): input:good.in output:good.out Time Limits: 2000 ms Mem ...
- JZOJ 3518. 【NOIP2013模拟11.6A组】进化序列(evolve)
3518. [NOIP2013模拟11.6A组]进化序列(evolve) (File IO): input:evolve.in output:evolve.out Time Limits: 1000 ...
- JZOJ 3526. 【NOIP2013模拟11.7A组】不等式(solve)
3526. [NOIP2013模拟11.7A组]不等式(solve) (File IO): input:solve.in output:solve.out Time Limits: 1000 ms M ...
- JZOJ【NOIP2013模拟联考14】隐藏指令
JZOJ[NOIP2013模拟联考14]隐藏指令 题目 Description 在d维欧几里得空间中,指令是一个长度为2N的串.串的每一个元素为d个正交基的方向及反方向之一.例如,d = 1时(数轴) ...
- [jzoj 5343] [NOIP2017模拟9.3A组] 健美猫 解题报告 (差分)
题目链接: http://172.16.0.132/senior/#main/show/5343 题目: 题解: 记旋转i次之后的答案为$ans_i$,分别考虑每个元素对ans数组的贡献 若$s_i& ...
- [JZOJ 4307] [NOIP2015模拟11.3晚] 喝喝喝 解题报告
题目链接: http://172.16.0.132/senior/#main/show/4307 题目: 解题报告: 题目询问我们没出现坏对的连续区间个数 我们考虑从左到有枚举右端点$r$,判断$a[ ...
- JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)
3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB De ...
随机推荐
- Linux环境安装jdk12-rpm
此博客只是本人的个人学习记录,若有什么误导观看者,请不要怪我... 1.环境准备: Linux环境:Centos7 jdk版本:JavaSE12 下载地址:https://www.oracl ...
- cout,cerr和clog的区别
官方解释: cout——Standard output stream Object of class ostream that represents the standard output strea ...
- 堆,set,优先队列
当我们需要高效的完成以下操作时: 1.插入一个元素 2.取得最小(最大)的数值,并且删除 能够完成这种操作的数据结构叫做优先队列 而能够使用二叉树,完成这种操作的数据结构叫做堆(二叉堆) 堆与优先队列 ...
- dubbo直连提供者 & 只订阅 & 只注册
1. dubbo直连提供者 在开发及测试环境下,经常需要绕过注册中心,只测试指定服务提供者,这时候可能需要点对点直连,点对点直连方式,将以服务接口为单位,忽略注册中心的提供者列表,A 接口配置点 ...
- insert主键返回 selectKey使用
有时候新增一条数据,知道新增成功即可,但是有时候,需要这条新增数据的主键,以便逻辑使用,再将其查询出来明显不符合要求,效率也变低了. 这时候,通过一些设置,mybatis可以将insert的数据的主键 ...
- Oracle SQL性能优化总结
1. SQL语句执行步骤 语法分析> 语义分析> 视图转换 >表达式转换> 选择优化器 >选择连接方式 >选择连接顺序 >选择数据的搜索路径 >运行“执 ...
- Elasticsearch一些使用笔记(持续更新)
这篇博客记录这一些运维ES的一些经验. 1.节点磁盘使用率过高,导致ES集群shard无法分配,丢失数据? 有两个配置,分配副本的时候 参数名称 默认值 含义 cluster.routing.allo ...
- 关于 git 本地创建 SSH Key 遇到的一点问题(①file to save the key & ②the authenticity of host...)
背景 由于想测试一下 SSH Key 创建的路径(.ssh 目录路径)对于不同位置 git 项目是否有效. 比如,.ssh 默认在 C:\[users]\[username] 目录下,而项目 proj ...
- 四, 判断语句; 循环; 使用dict和set
1) 练习 小明身高1.75,体重80.5kg.请根据BMI公式(体重除以身高的平方)帮小明计算他的BMI指数,并根据BMI指数: 低于18.5:过轻 18.5-25:正常 25-28:过重 28- ...
- Web前端-关于jQuerry
jQuery-The write less,do more,jacascript library 非常方便的js库,封装了许多有用的功能. 1.jq与js对象之间的转换 <script> ...