传送门:http://codeforces.com/contest/788/problem/B

好题!好题!

首先图不连通的时候肯定答案是0,我们下面讨论图联通的情况

首先考虑,如果我们每条边都经过两边,那么肯定是可行的

因为这样相当于把每条边复制一遍,然后问图中是否存在欧拉路径

既然每条边都出现了两遍,那么所有点的度数一定都是偶数,所以肯定有欧拉路径

现在考虑将某两条边变成出现一遍,这样的话可能会有一些点的度数变成奇数

如果我们把两条非自环的边变成出现一遍,并且这两条边不交于同一个点,那么就会有四个度数为奇数的点,则图中不存在欧拉路径

如果我们把两条非自环的边变成出现一遍,并且这两条边交于同一个点,那么就会有两个度数为奇数的点,存在欧拉路径

如果我们把两条自环边变成出现一遍,所有点的度数仍然为偶数,存在欧拉路径

如果我们把一条自环,一条非自环的边变成出现一遍,那么就会有两个度数为奇数的点,存在欧拉路径

所以一共就几种情况,除去判联通的部分,我们只要记录每个点的度数(不含自环)和自环的数量就好了

因为题目中保证一条边不会出现两遍,所以我们的方法才是可行的

代码:

 #include <bits/stdc++.h>

 using namespace std;
typedef long long ll;
const int MAXN = ; int n, m; namespace Graph {
int head[MAXN], nxt[MAXN<<], to[MAXN<<], eidx;
void init() {
eidx = ;
memset( head, -, sizeof(head) );
}
void adde( int u, int v ) {
to[eidx] = v, nxt[eidx] = head[u], head[u] = eidx++;
}
} bool ing[MAXN] = {}, vis[MAXN] = {}; // ing表示这个点是否存在于图中,因为题目只要求边互相联通,所以对于没有度数的点可以看做不存在
queue<int> q;
bool bfs() { // bfs判联通
using namespace Graph;
for( int i = ; i <= n; ++i )
if( ing[i] ) {
q.push(i), vis[i] = true;
break;
}
while( !q.empty() ) {
int u = q.front(); q.pop();
for( int i = head[u]; ~i; i = nxt[i] ) {
int v = to[i];
if( vis[v] ) continue;
q.push(v), vis[v] = true;
}
}
for( int i = ; i <= n; ++i )
if( ing[i] && !vis[i] )
return false;
return true;
} int deg[MAXN] = {}, loop = ; // 每个点的度数(不含自环)和总的自环数量
int main() {
scanf( "%d%d", &n, &m );
Graph::init();
for( int i = ; i < m; ++i ) {
int u, v; scanf( "%d%d", &u, &v );
ing[u] = ing[v] = true;
if( u != v ) {
Graph::adde(u,v), ++deg[u];
Graph::adde(v,u), ++deg[v];
} else { // 自环
Graph::adde(u,v), ++loop;
}
}
if( !bfs() || m < ) {
puts("");
return ;
}
ll ans = (ll)loop*(m-loop) + (ll)loop*(loop-)/; // 选一个自环和一个非自环,或者选两个自环
for( int i = ; i <= n; ++i )
ans += (ll)deg[i]*(deg[i] - )/; // 选两个非自环,且交于同一点的边
cout << ans << endl;
return ;
}

【题解】Weird journey Codeforces 788B 欧拉路的更多相关文章

  1. Weird journey CodeForces - 788B (路径计数)

    大意:$n$结点$m$条边无向图, 满足 $(1)$经过$m-2$条边$2$次 $(2)$经过其余$2$条边$1$次 的路径为好路径, 求所有好路径数 相当于边加倍后再删除两条边, 求欧拉路条数 首先 ...

  2. CodeForces 788B - Weird journey [ 分类讨论 ] [ 欧拉通路 ]

    题意: 给出无向图. good way : 仅有两条边只经过一次,余下边全经过两次的路 问你共有多少条不同的good way. 两条good way不同仅当它们所经过的边的集合中至少有一条不同 (很关 ...

  3. CodeForces - 788B Weird journey 欧拉路

    题意:给定n个点,m条边,问能否找到多少条符合条件的路径.需要满足的条件:1.经过m-2条边两次,剩下两条边1次  2.任何两条路的终点和起点不能相同. 欧拉路的条件:存在两个或者0个奇度顶点. 思路 ...

  4. Codeforces 789D Weird journey - 欧拉路 - 图论

    Little boy Igor wants to become a traveller. At first, he decided to visit all the cities of his mot ...

  5. Codeforces Round #407 (Div. 2) D. Weird journey(欧拉路)

    D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

  6. 【cf789D】Weird journey(欧拉路、计数)

    cf788B/789D. Weird journey 题意 n个点m条边无重边有自环无向图,问有多少种路径可以经过m-2条边两次,其它两条边1次.边集不同的路径就是不同的. 题解 将所有非自环的边变成 ...

  7. Codeforces Round #407 (Div. 1) B. Weird journey —— dfs + 图

    题目链接:http://codeforces.com/problemset/problem/788/B B. Weird journey time limit per test 2 seconds m ...

  8. codeforces 407 div1 B题(Weird journey)

    codeforces 407 div1 B题(Weird journey) 传送门 题意: 给出一张图,n个点m条路径,一条好的路径定义为只有2条路径经过1次,m-2条路径经过2次,图中存在自环.问满 ...

  9. CodeForces - 789D Weird journey

    D. Weird journey time limit per test 2 seconds memory limit per test 256 megabytes input standard in ...

随机推荐

  1. 227. Mock Hanoi Tower by Stacks【LintCode java】

    Description In the classic problem of Towers of Hanoi, you have 3 towers and N disks of different si ...

  2. Python基础 之 tuple类-元组 和 dict类-字典

    tuple 元组 一.tuple 类的基本属性 1.元组,有序:元素不可被修改,不能被增加或者删除tuple类 tu = (111,22,33,44) 一般写元组的时候,推荐在最后加入,和类方法进行区 ...

  3. fragment的介绍与使用

    稍稍摘录一段Fragment.java中的说明文档. /** * A Fragment is a piece of an application's user interface or behavio ...

  4. Python中的list

    list的创建 1 字面量 >>>L = [1, 2, 3] [1, 2, 3] 2 通过iterable可迭代对象,比如str对象,range对象,map对象 >>&g ...

  5. 图的遍历——DFS(邻接矩阵)

    递归 + 标记 一个连通图只要DFS一次,即可打印所有的点. #include <iostream> #include <cstdio> #include <cstdli ...

  6. Red and Black(DFS深搜实现)

    Description There is a rectangular room, covered with square tiles. Each tile is colored either red ...

  7. 第三周的psp

    PSP: 进度条: 累计进度图: 本周PSP饼状图:

  8. TCP系列26—重传—16、重组包

    一.介绍 在TCP重传的时候,并没有限制TCP只能重传与初传完全相同的报文段大小,TCP允许执行重组包(repacketization),发送一个更大的TCP报文段,进而增加性能.TCP在重传时候允许 ...

  9. 含html转义字符编码(&#22235;)转换--python

    在抓取下来的网页源码显示的是如下的内容,而不是可读性的汉字 (当然,如果是在Web页面上展示,则实体会自动被浏览器转为原字符,正常显示) 经查资料后得知, 在网页中以四开头的是HTML实体,具体什么是 ...

  10. Mysql查询优化从入门到跑路(一)数据库与关系代数

    1.怎样才算是数据库?     ACID,是指在数据库管理系统中事务所具有的四个特性     1)原子性     2)一致性     3)隔离性     4)持久性       关系数据库,基于关系代 ...