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)(深度优先生成树)的更多相关文章

  1. JZOJ 3505. 【NOIP2013模拟11.4A组】积木(brick)

    3505. [NOIP2013模拟11.4A组]积木(brick) (File IO): input:brick.in output:brick.out Time Limits: 1000 ms Me ...

  2. JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C

    3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...

  3. JZOJ 3508. 【NOIP2013模拟11.5B组】好元素

    3508. [NOIP2013模拟11.5B组]好元素(good) (File IO): input:good.in output:good.out Time Limits: 2000 ms  Mem ...

  4. JZOJ 3518. 【NOIP2013模拟11.6A组】进化序列(evolve)

    3518. [NOIP2013模拟11.6A组]进化序列(evolve) (File IO): input:evolve.in output:evolve.out Time Limits: 1000 ...

  5. JZOJ 3526. 【NOIP2013模拟11.7A组】不等式(solve)

    3526. [NOIP2013模拟11.7A组]不等式(solve) (File IO): input:solve.in output:solve.out Time Limits: 1000 ms M ...

  6. JZOJ【NOIP2013模拟联考14】隐藏指令

    JZOJ[NOIP2013模拟联考14]隐藏指令 题目 Description 在d维欧几里得空间中,指令是一个长度为2N的串.串的每一个元素为d个正交基的方向及反方向之一.例如,d = 1时(数轴) ...

  7. [jzoj 5343] [NOIP2017模拟9.3A组] 健美猫 解题报告 (差分)

    题目链接: http://172.16.0.132/senior/#main/show/5343 题目: 题解: 记旋转i次之后的答案为$ans_i$,分别考虑每个元素对ans数组的贡献 若$s_i& ...

  8. [JZOJ 4307] [NOIP2015模拟11.3晚] 喝喝喝 解题报告

    题目链接: http://172.16.0.132/senior/#main/show/4307 题目: 解题报告: 题目询问我们没出现坏对的连续区间个数 我们考虑从左到有枚举右端点$r$,判断$a[ ...

  9. JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)

    3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  De ...

随机推荐

  1. 一、下载安装superset

    1.环境介绍: 操作系统:Windows 10 python版本:3.73 2.创建虚拟环境: 打开命令行窗口,使用安装python自带的pip命令,下载pinenv 虚拟环境工具, pip inst ...

  2. 为什么HashMap线程不安全,Hashtable和ConcurrentHashMap线程安全

    HashMap源码 public V put(K key, V value) { return putVal(hash(key), key, value, false, true); } final ...

  3. Java并发编程之美之并发编程线程基础

    什么是线程 进程是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,线程则是进程的一个执行路径,一个进程至少有一个线程,进程的多个线程共享进程的资源. java启动main函数其实就 ...

  4. TV 丽音(NICAM)功能

    丽音意谓「接近即时的缩扩音频多路广播」 丽音使用数码技术,把电视台发送的两条音频讯号数码化后进行压缩,传送后再在接收机里扩大还原.数码化使用的是14位元 PCM,32千赫采样. 这种广播法可以播出优质 ...

  5. python安装过程中的一些问题

    因为看到大神的教程是基于python V2.7,下载该版本且安装成功. 安装目录: https://www.python.org/download/releases/2.7/ 根据系统进行安装包下载 ...

  6. node命令行工具—cf-cli

    音乐分享: 钢心 - <龙王> 初喜<冠军>后喜<龙王> (PS:听一次钢心乐队的演出后采访才知道 “龙王”隐喻的是一起喝酒的老铁....) ——————————— ...

  7. Access提示Insert Into 语法错误解决办法总结

    1.关键字:如果你的数据库的表的设计包含了Access包含的关键字,则在插入的时候会出现“Insert Into 语法错误” 例如: string sqlText = String.Format(&q ...

  8. C#发送带附件的邮件的代码

    如下的代码是关于C#发送带附件的邮件的代码. MailMessage m = new MailMessage();m.Subject = "File attachment!";m. ...

  9. mysql 与 oracle 的连表update

    mysql: update 表A a,表B b set a.xx=b.xx where a.id=b.id; oracle update 表A set a.xx=(select b.xx from 表 ...

  10. 网页常用Js代码

    1.后退前进 <input type="button" value="后退" onClick="history.go(-1)"> ...