题目:http://codeforces.com/contest/36/problem/E

给定一张无向图,要求输出两条欧拉路覆盖所有边;

分类讨论,首先判-1:有两个以上连通块 / 有四个以上奇度数点 / 只有一条边 / 有两个连通块而其中一个连通块里有四个奇度数点 (/ 有连通块里有奇数个奇度数点);

然后分两个连通块和一个连通块的情况进行 dfs 找欧拉路(模板 dfs );

注意可能没有奇度数的点,也就是有欧拉回路,所以不仅找奇度数点进行 dfs ,还要在那之后 dfs 仍然没有被走过的点;

明明是模仿题解写的竟然还调了两小时...码力++...

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int const maxn=;
int n,m,d[maxn],ans[maxn],tot,fa[maxn],cnt,c[maxn],hd[maxn],ct=;
bool vis[maxn],used[maxn];
struct N{
int to,nxt;
N(int t=,int n=):to(t),nxt(n) {}
}ed[maxn<<];
void add(int x,int y){ed[++ct]=N(y,hd[x]); hd[x]=ct;}
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
void dfs(int x)
{
vis[x]=;
for(int i=hd[x];i;i=hd[x])
{
hd[x]=ed[i].nxt;
if(used[i>>])continue;
used[i>>]=; dfs(ed[i].to); ans[++tot]=(i>>);
}
}
int main()
{
freopen("input.txt","r",stdin);
freopen("output.txt","w",stdout);
n=; scanf("%d",&m);//不能是 n=10005
for(int i=;i<=n;i++)fa[i]=i;//!!
for(int i=,x,y;i<=m;i++)
{
scanf("%d%d",&x,&y);
add(x,y); add(y,x); d[x]++; d[y]++;
if(find(x)!=find(y))fa[find(x)]=find(y);
}
for(int i=;i<=n;i++) if(d[i]&) c[find(i)]++;
for(int i=;i<=n;i++) if(c[i]&){printf("-1\n"); return ;}
for(int i=,sum=;i<=n;i++)
{
if(d[i])cnt+=(i==find(i));
if(c[i])sum+=c[i];
if(sum>){printf("-1\n"); return ;}
}
if(cnt>){printf("-1\n"); return ;}
if(cnt==)
{
for(int i=;i<=n;i++) if(c[i]==){printf("-1\n"); return ;}
for(int i=;i<=n;i++)
if(!vis[i]&&(d[i]&))
{
tot=; dfs(i); printf("%d\n",tot);
for(int j=tot;j;j--)printf("%d ",ans[j]); printf("\n");
}
for(int i=;i<=n;i++)//欧拉回路
if(!vis[i]&&d[i])
{
tot=; dfs(i); printf("%d\n",tot);
for(int j=tot;j;j--)printf("%d ",ans[j]); printf("\n");
}
}
else
{
bool fl=;
for(int i=;i<=n;i++) if(c[i]==)fl=;
if(fl)
{
for(int i=;i<=n;i++) if(d[i]&)
{
for(int j=i+;j<=n;j++)
if(d[j]&){d[i]++; d[j]++; add(i,j); add(j,i); break;}
break;
}
for(int i=;i<=n;i++)
if(!vis[i]&&(d[i]&)){tot=; dfs(i); break;}
for(int i=;i<=tot;i++) if(ans[i]==m+)
{
printf("%d\n",i-);
for(int j=;j<i;j++)printf("%d ",ans[j]); printf("\n");
printf("%d\n",tot-i);
for(int j=i+;j<=tot;j++)printf("%d ",ans[j]);
break;
}
}
else
{
for(int i=;i<=n;i++)
if(!vis[i]&&(d[i]&)){tot=; dfs(i);}
for(int i=;i<=n;i++)//欧拉回路
if(!vis[i]&&d[i]){tot=; dfs(i);}
if(tot<=){printf("-1\n"); return ;}//只有一条边
printf("1\n%d\n%d\n",ans[],tot-);
for(int i=;i<=tot;i++)printf("%d ",ans[i]);
}
}
return ;
}

CF36 E Two Paths——欧拉(回)路的更多相关文章

  1. 拓扑排序&&欧拉(回)路

    摘要:最近是不适合写代码么?忘记初始化wa到死<_=_=_>.唔--最近在学习图论,从基础搞起,先搞了拓扑排序和欧拉(回)路. Part 0. 拓扑排序 ==挖坑== Part 1. 欧拉 ...

  2. Codeforces 871D Paths (欧拉函数 + 结论)

    题目链接  Round  #440  Div 1  Problem D 题意   把每个数看成一个点,如果$gcd(x, y) \neq 1$,则在$x$和$y$之间连一条长度为$1$的无向边.   ...

  3. Poj 2337 Catenyms(有向图DFS求欧拉通路)

    题意: 给定n个单词, 问是否存在一条欧拉通路(如acm,matal,lack), 如果存在, 输出字典序最小的一条. 分析: 这题可以看作http://www.cnblogs.com/Jadon97 ...

  4. POJ 2337 Catenyms(有向图的欧拉通路)

    题意:给n个字符串(3<=n<=1000),当字符串str[i]的尾字符与str[j]的首字符一样时,可用dot连接.判断用所有字符串一次且仅一次,连接成一串.若可以,输出答案的最小字典序 ...

  5. HDU1116 Play on Words(有向图欧拉通路)

    我把单词当作点,然后这样其实是不对的,这样就要判定是否是哈密顿通路.. 这题应该把单词的首尾单词当作点,而单词本身就是边,那样就是判定欧拉通路了. 有向图包含欧拉通路的充要条件是:首先基图连通,然后是 ...

  6. POJ 1386 有向图欧拉通路

    题意:给你一些字符串,这些字符串可以首位相接(末位置如果和另一个字符串的首位置相同的话就可以相连) .然后问你是否可以全部连起来. 思路:就是取出每个字符串的首尾位置,然后求出出度和入度,根据有向欧拉 ...

  7. UVA 10129-Play on Words(欧拉通路)

    题意:给N个单词,判断是否单词首尾(前一个单词的尾字符与后一个单词的头字符相同)相连能否形成一条链. 解析:找欧拉通路(欧拉回路或是欧拉链路),但这题事先需要并查集一下,判断是否只属于一个集合,如aa ...

  8. CodeForces - 508D Tanya and Password(欧拉通路)

    Description While dad was at work, a little girl Tanya decided to play with dad characters. She has ...

  9. POJ--1300--Door Man【推断无向图欧拉通路】

    链接:http://poj.org/problem?id=1300 题意:有n个房间.每一个房间有若干个门和别的房间相连.管家从m房间開始走.要回到自己的住处(0),问是否有一条路能够走遍全部的门而且 ...

随机推荐

  1. 如何快速的vue init 属于自己的vue模板?

    相信很多接触过vue的小伙伴非常熟悉了,我们在开启项目之前都需要vue init webpack xx来初始化自己的项目目录.但是在实际开发中我们往往会根据公司要求或者业务的需要会对目录进行局部的调整 ...

  2. UVA - 1374 Power Calculus (dfs迭代加深搜索)

    题目: 输入正整数n(1≤n≤1000),问最少需要几次乘除法可以从x得到xn ?在计算过程中x的指数应当总是正整数. 思路: dfs枚举次数深搜 注意: 1.指数如果小于0,就退出当前的搜索 2.n ...

  3. Python学习笔记(2)数值类型

    进制转换 int函数任意进制转换为10进制 第一个参数传入一个字符串,任意进制的,第二个参数传入对这个字符串的解释,解释他为几进制 hex oct bin转换进制为16 8 或者2进制 例题中石油87 ...

  4. type、object、class之间的关系

    class Foo: pass print(type(int)) # <class 'type'> print(type(str)) # <class 'type'> prin ...

  5. python黑科技库:FuckIt.py,让你代码从此远离bug

    今天给你推荐的这个库叫 “FuckIt.py”,名字一看就是很黄很暴力的那种,作者是这样介绍它的: FuckIt.py uses state-of-the-art technology to make ...

  6. BZOJ 4415 洛谷 3988 [Shoi2013]发牌

    [题解] 权值线段树.查询当前牌堆顶的牌并且删掉就好了. #include<cstdio> #include<algorithm> #define N 3000010 #def ...

  7. wannafly-day1 Problem A - Birthday

    思路:队友贪心WA了,然后就没有然后了,自己也是第一次接触最小费用流的题.借这个题来学习一下,利用Spfa每次来找到一个最短的路径同时保存路径,每一次寻找最短路径就将这条路的最小费用流给剪掉,然后继续 ...

  8. springcloud(八):熔断器Hystrix

    熔断器 雪崩效应 在微服务架构中通常会有多个服务层调用,基础服务的故障可能会导致级联故障,进而造成整个系统不可用的情况,这种现象被称为服务雪崩效应.服务雪崩效应是一种因“服务提供者”的不可用导致“服务 ...

  9. 【Codeforces 375A】Divisible by Seven

    [链接] 我是链接,点我呀:) [题意] 让你把一个包含数字1,6,8,9的数字重新组合,使得组合成的数字能被7整除 [题解] 我们先提取出来1,6,8,9各1个 然后把剩余的len-4个数字除了0之 ...

  10. RabbitMQ-rabbitMq各个特性的使用(三)

    准备 1.引入客户端和配置文件依赖类 <dependency> <groupId>com.rabbitmq</groupId> <artifactId> ...