CF19 E Fairy——树上差分
题目:http://codeforces.com/contest/19/problem/E
先把图连成一棵树,然后对于每条非树边,判断它是在奇环中还是偶环中;
把环上的点打上相应的差分标记,并记录有多少个奇环;
dfs 出来后判断,若没有奇环,那么所有边都可以删;
若有奇环 k 个,遍历边,在 k 个奇环中而不在偶环中的边可以删;
如果一条边既在奇环中又在偶环中,那么若删掉它,原来的一奇环一偶环会合并成一个大奇环,所以这种边不能删;
写、调了整整两小时,改了许多冗余的地方和错误的地方才终于A了,我这代码能力...
码力++!
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int const maxn=2e4+;
int n,m,fa[maxn],sf[maxn],sg[maxn],g[maxn],f[maxn],ans[maxn],ns;
int col[maxn],hd[maxn],ct,cnt,qhd[maxn],numj;
bool vis[maxn];
struct N{
int to,nxt,edge;
N(int t=,int n=,int e=):to(t),nxt(n),edge(e) {}
}ed[maxn<<],q[maxn];
struct T{
int ff,gg;
T(int f=,int g=):ff(f),gg(g) {}
};
inline int rd()
{
int ret=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-; ch=getchar();}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return ret*f;
}
inline int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
inline void add(int x,int y,int e){ed[++ct]=N(y,hd[x],e); hd[x]=ct;}
inline void ad(int x,int y,int e){q[++cnt]=N(y,qhd[x],e); qhd[x]=cnt;}
inline void dfs2(int x,int pre)
{
vis[x]=; col[x]=!col[pre];
for(register int i=qhd[x];i;i=q[i].nxt)
{
int u=q[i].to;
if(!vis[u])continue;
int lca=find(u);
if(col[u]==col[x])
{
// f[u]++,f[i]++,f[pr[lca]]-=2,numj++;
f[u]++,f[x]++,f[lca]-=,numj++;
sf[q[i].edge]=;
}
else
{
// g[u]++,g[i]++,g[pr[lca]]-=2,numo++;
g[u]++,g[x]++,g[lca]-=;
}
}
for(register int i=hd[x],u;i;i=ed[i].nxt)
if((u=ed[i].to)!=pre)dfs2(u,x);
fa[x]=pre;
}
inline T dfs3(int x,int pre)
{
int smf=f[x],smg=g[x]; vis[x]=;//smf,smg!=0!!!
for(register int i=hd[x],u;i;i=ed[i].nxt)
{
if((u=ed[i].to)==pre)continue;
T k=dfs3(u,x);int e=ed[i].edge;
sf[e]=k.ff; sg[e]=k.gg;
smf+=k.ff; smg+=k.gg;
}
return T(smf,smg);
}
int main()
{
n=rd(); m=rd();
for(register int i=;i<=n;i++)fa[i]=i;
for(register int i=,u,v;i<=m;i++)
{
u=rd(); v=rd();
if(find(u)!=find(v))
{
fa[find(u)]=find(v);
add(u,v,i); add(v,u,i);
}
else ad(u,v,i),ad(v,u,i);
}
for(register int i=;i<=n;i++)fa[i]=i;
for(int i=;i<=n;i++)if(!vis[i])dfs2(i,);//不仅dfs(1,0)
memset(vis,,sizeof vis);
if(!numj)
{
printf("%d\n",m);
for(int i=;i<=m;i++)printf("%d ",i);
return ;
}
for(int i=;i<=n;i++)if(!vis[i])dfs3(i,);
memset(vis,,sizeof vis);
for(register int i=;i<=m;i++)
if(sf[i]==numj&&!sg[i])ans[++ns]=i;
printf("%d\n",ns);
sort(ans+,ans+ns+);
for(register int i=;i<=ns;i++)printf("%d ",ans[i]);
return ;
}
CF19 E Fairy——树上差分的更多相关文章
- CF 19E Fairy——树上差分
题目:http://codeforces.com/contest/19/problem/E 去掉一条边,使无向图变成二分图. 该边应该被所有奇环经过,且不被偶环经过. 因为一条非树边一定只在一个环里. ...
- CF19E Fairy(树上差分)
题目描述 很久很久以前,有一个仙女叫做A.有一天一个少年B找到她,并且请求她预测他的未来.仙女看着她的水晶球,说这位少年不久将遇见世界上最美丽的公主,并且将迎娶她为妻.然后仙女在一张纸上画了n个点,并 ...
- BZOJ4424/CF19E Fairy(dfs树+树上差分)
即删除一条边使图中不存在奇环.如果本身就是个二分图当然任意一条边都可以,先check一下.否则肯定要删除在所有奇环的交上的边. 考虑怎么找这些边.跑一遍dfs造出dfs树,找出返祖边构成的奇环.可以通 ...
- 【BZOJ-4326】运输计划 树链剖分 + 树上差分 + 二分
4326: NOIP2015 运输计划 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 703 Solved: 461[Submit][Status] ...
- [luogu P3128][USACO15DEC]Max Flow [LCA][树上差分]
题目描述 Farmer John has installed a new system of pipes to transport milk between the stalls in his b ...
- 树上差分 (瞎bb) [树上差分][LCA]
做noip2015的运输计划写了好久好久写不出来 QwQ 于是先来瞎bb一下树上差分 混积分 树上差分有2个常用的功能: (1)记录从点i到i的父亲这条路径走过几次 (2)将每条路径(s,t ...
- [填坑]树上差分 例题:[JLOI2014]松鼠的新家(LCA)
今天算是把LCA这个坑填上了一点点,又复习(其实是预习)了一下树上差分.其实普通的差分我还是会的,树上的嘛,也是懂原理的就是没怎么打过. 我们先来把树上差分能做到的看一下: 1.找所有路径公共覆盖的边 ...
- 【NOIP2016】【LCA】【树上差分】【史诗级难度】天天爱跑步
学弟不是说要出丧题吗>>所以我就研究了1天lca又研究了1天tj然后研究了一天天天爱跑步,终于写了出来.(最后的平均用时为240ms...比学弟快了1倍...) 题意:给你颗树,然后有m个 ...
- BZOJ_4238_电压_树上差分+dfs树
BZOJ_4238_电压_树上差分+dfs树 Description 你知道Just Odd Inventions社吗?这个公司的业务是“只不过是奇妙的发明(Just Odd Inventions)” ...
随机推荐
- day02 Python完结
一. 常用数据类型及内置法 1 列表 定义: 列表是Python中内置有序.可变序列,列表的所有元素放在一对中括号“[]”中,并使用逗号分隔开: 当列表元素增加或删除时,列表对象自动进行扩展或收缩内存 ...
- jdbcTemplate传参使用Map或List
List传参方式 举个例子 sql = "select * from table where id=? and param=?": sql中的参数要用?形式,然后使用list.ad ...
- JAVA基础——链表结构之双端链表
双端链表:双端链表与传统链表非常相似.只是新增了一个属性-即对最后一个链结点的引用 如上图所示:由于有着对最后一个链结点的直接引用.所以双端链表比传统链表在某些方面要方便.比如在尾部插入一个链结点.双 ...
- HDU_5783_DivideTheSequence
HDU_5783_DivideTheSequence 点击打开链接 题意: 生成尽量多的连续的子串,且子串的前缀和大于等于0,输出符合题意的子串的数量. 这题目是参加四月份的个人训练赛遇到的,挺水的 ...
- Centos6文本安装教程
Centos6.4文本方式安装 虚拟机中文本安装(内存512),内存大于512默认为图形安装 1.选择安装媒体,在vbox中选skip跳过 2.选择安装语言(chinese(simplifired)简 ...
- 一:安装centos 7最小编程环境 xfce桌面
1, u盘制作安装盘------------------------------------------------------安装时, table或者e进入编辑选项 如果不知道你的u盘的盘符 ...
- uva 1444 Knowledge for the masses
uva 1444 Description You are in a library equipped with bookracks that move on rails. There are ma ...
- WordCountPro,完结撒花
WordCountPro,完结撒花 软测第四周作业 一.概述 该项目github地址如下: https://github.com/YuQiao0303/WordCountPro 该项目需求如下: ht ...
- Leetcode 51.N后问题
N后问题 n 皇后问题研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击. 上图为 8 皇后问题的一种解法. 给定一个整数 n,返回所有不同的 n 皇后问题的解决方案. ...
- JS中showModalDialog 详细使用方法
基本介绍: showModalDialog() (IE 4+ 支持) showModelessDialog() (IE 5+ 支持) window.showModalDialog() 方法用来创建一个 ...