[pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=61845295

题目大意

给定n个点m条边的无向图,不同点之间只有一条边,但可以有自环,求本质不同的合法路径的总数

一条合法路径是指经过m-2条边恰好2次,2条边1次

两条路径不同指存在一条边在两种路径中经过的次数不同

input

第一行两个整数n,m

接下来m行每行两个整数u,v,表示u到v有一条边

output

一个整数表示答案

hint

1<=n,m<=10^5,1<=u,v<=n

第一眼看到这个题的时候,就有一点思路了。m-2条边经过两次,一条边经过两次,实质上就是一去一反。

为什么会想到这个呢?想想小学的时候学一笔画问题,对于不能一笔画的图我们怎么强行的“一笔画”。就是把笔画过去,又画回来,这样一条边就经过了两次。嘛,这也算是一笔画问题的“性质”吧。

回到问题来,我们希望去掉一团画了两次的路径,剩下的两条可以一笔画。两条边要能够一笔画,就必须要相邻。其相邻的两个点所连接的其他边结合“一去一反”的性质,可以证明在经过了2次后一定能回到出发点。

然后就很容易啦。枚举每个点,从其连接的边中选择两条作为经过1次的边,就有cnt[i]*(cnt[i]-1)/2种选法,求和即可

but。。。

我只得了30分?! 立了一个flag,打脸打的啪啪响。为什么呢?

1、注意题目:可能有自环

自环就像是一个中转站,在经过这个点的时候,想沿着这个环走几次就走几次,显然一次也是可以的。那么,一条自环的边可以和任意一条边组合,就变成了去掉这个自环后,选一条边走一次,其他边走两次的问题了,在经过自环的点时顺便跑一下环,明显任何一条边都可以。

所以还要统计自环对答案的贡献。

2、图可能不连通

但是要注意,如果只有单个的点孤立出来,这样的图仍然是可以的。我们所谓的联通是指边在一个联通图中。

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std; const int N=100000+5; ll deg[N],cir[N],cntc=0,edge[N][2],fa[N];
int n,m;
ll tot=0,hasc=0;
ll head[N],end[2*N],nxt[2*N],hh=0;
bool has[N]; int getfa(int x){
if(fa[x]==x) return x;
return fa[x]=getfa(fa[x]);
}
int main(){
scanf("%d%d",&n,&m);
int u,v;
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1;i<=m;i++){
scanf("%d%d",&u,&v);
deg[u]++,deg[v]++;
edge[i][0]=u,edge[i][1]=v;
int fau=getfa(u),fav=getfa(v);
if(fau!=fav) fa[fau]=fav;
if(u==v) cir[++cntc]=u,deg[u]--;
}
for(int i=1;i<=m;i++){
u=edge[i][0];
int j;
for(j=1;j<=m&&j==i;j++);
v=edge[j][0];
if(getfa(u)!=getfa(v)){
printf("0");
return 0;
}
v=edge[j][1];
if(getfa(u)!=getfa(v)){
printf("0");
return 0;
}
}
for(int i=1;i<=n;i++)
tot+=deg[i]*(deg[i]-1)/2;
for(int i=1;i<=cntc;i++){
tot+=(m-deg[cir[i]]);
if(has[cir[i]]==0){
hasc++;
has[cir[i]]=1;
}
}
tot-=(hasc-1)*hasc/2;
printf("%lld",tot);
return 0;
}

总结:

1、从题目出发思考问题,不要想着去套算法。生活经验或是以前学过的知识可能是可以触类旁通的。

2、思考问题要思考全面。题目中提示了一些特殊点,要去思考其可能的情况。

【CodeForces 788B】奇妙的一笔画问题的更多相关文章

  1. 【题解】Weird journey Codeforces 788B 欧拉路

    传送门:http://codeforces.com/contest/788/problem/B 好题!好题! 首先图不连通的时候肯定答案是0,我们下面讨论图联通的情况 首先考虑,如果我们每条边都经过两 ...

  2. CodeForces - 788B Weird journey 欧拉路

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

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

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

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

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

  5. Codeforces Round #513 总结

    首次正式的$Codeforces$比赛啊,虽然滚粗了,然而终于有$rating$了…… #A  Phone Numbers 签到题,然而我第一次写挂了(因为把11看成8了……) 只需要判断一下有多少个 ...

  6. Codeforces Beta Round #49 (Div. 2)

    Codeforces Beta Round #49 (Div. 2) http://codeforces.com/contest/53 A #include<bits/stdc++.h> ...

  7. 788B(dfs+xjb)

    题目链接: http://codeforces.com/problemset/problem/788/B 题意: 给出一个有 n 个顶点和 m 条边的图(没有重边,可能有自环), 可以从中任意一个顶点 ...

  8. BFS Codeforces Round #297 (Div. 2) D. Arthur and Walls

    题目传送门 /* 题意:问最少替换'*'为'.',使得'.'连通的都是矩形 BFS:搜索想法很奇妙,先把'.'的入队,然后对于每个'.'八个方向寻找 在2*2的方格里,若只有一个是'*',那么它一定要 ...

  9. 【codeforces 789D】Weird journey

    [题目链接]:http://codeforces.com/problemset/problem/789/D [题意] 给你n个点,m条边; 可能会有自环 问你有没有经过某两条边各一次,然后剩余m-2条 ...

随机推荐

  1. C编译器MinGW安装、下载及在notepad++中运行C程序

    一.C编译器MinGW的下载及安装步骤 打开MinGW官网:http://www.mingw.org/ 图一 图二 图三 图四 图五 图六 系统中配置环境变量: 图七 验证是否安装成功: CMD中运行 ...

  2. 不吹不擂,你想要的Python面试都在这里了【315+道题】+精心整理的解答

    Part01-Py基础篇(80) Part02-网络编程和并发(34) Part03-数据库和缓存(46) Part04-前端框架和其他(155) Part01-Py基础篇(80) 1.为什么学习Py ...

  3. 孤荷凌寒自学python第五十五天初识MongoDb数据库

    孤荷凌寒自学python第五十五天第一天初识MongoDb数据库 (完整学习过程屏幕记录视频地址在文末) 大家好,2019年新年快乐! 本来我想的是借新年第一天开始,正式尝试学习爬虫,结果今天偶然发现 ...

  4. 2 25urllib.py

    """ urllib.request.urlopen(url,data,timeout) """ # from urllib.request ...

  5. Actiivity 生命周期

    Actiivity 生命周期,如下图所示: onCreate onStart (onRestarted) onResume onPaused(to onResume(User navigates to ...

  6. jQuery遍历 filter()方法

    实例 改变所有 div 的颜色,然后向类名为 "middle" 的类添加边框: $("div").css("background", &qu ...

  7. web浏览器中的javascript -- 2

    在html里嵌入javascript: 在html文档里嵌入客户端javascript代码有4种方式: 1.内联,放置在<script>和</script>标签对之间; 2.放 ...

  8. VS调试时不捕捉Exception

    在方法上添加 [DebuggerHidden] 这样,发生错误的时候,VS就不会捕捉到这个错误,否则,会在错误的地方中断. [DebuggerHidden] public void DeleteAll ...

  9. CodeForces Round #515 Div.3 C. Books Queries

    http://codeforces.com/contest/1066/problem/C You have got a shelf and want to put some books on it. ...

  10. IO多路复用的理解

    最近看了<后台开发核心技术与应用实践>有关select.poll和epoll部分以及相关的一些博客,学习了这三个函数的使用方法和区别,写一个易理解的总结. IO多路复用 之前程序中使用的I ...