HZOI2019 星际旅行 欧拉路
题目大意:https://www.cnblogs.com/Juve/articles/11207540.html—————————>
题解:网上都是一句话题解:将所有的边拆成两条,问题变成去掉两条边,使得原图存在一条欧拉路径。注意新图中所有点的度数均为偶数,只需按照去掉任意2个自环、去掉任意1个自环和任意一条边、去掉两条有公共顶点的边进行讨论即可。注意图不连通的判断方式,不是点不连通,而是边不连通。
这显然十分晦涩难懂
题目要求m-2条边经过两次,2条边经过1次。
如果不考虑有两条边经过一次,那么把所有边经过两次就是走一个欧拉路,由起点走向终点
那么2条边经过一次怎么理解?就是由终点往回倒2条边
我们首先判断图的连通性,用并查集即可,但要判定单独的一个点在图的外面,没有任何边与它连通的情况(你也可以理解成只要所有的边在一个集合里就可以,不一定所有的点在同一集合中)
那么往回倒的这两条边有什么情况?
题中没有说不存在自环,那么倒回去的这两条边有三种情况:
1,两个自环
2,一个自环和一条非自环边
3,两条连在同一点的边
我们定义du[i]为不考虑自环情况下i的度,tot是自环的个数,
sum=($\sum_\limits{i=1}^{n}$du[i])/2,(除以2是因为一条边连接了两个点,所以会算重)
对于第一种情况,ans1=tot*(tot-1)/2(等价与从tot个自环选出2个不重复的,$C_{tot}^{2}$)
第二种情况:ans2=tot*sum(自环中选一个,非自环边选一个)
第三中情况:ans3=$\sum_\limits{i=1}^{n}$du[i]*(du[i]-1)/2(从与i相连的边中选出不重复的两条,$C_{du[i]}^{2}$)。
最终的答案就是三种情况相加。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#define MAXN 100005
#define ll long long
using namespace std;
ll fa[MAXN],n,m,du[MAXN],tot_c=0,ans=0,du2[MAXN],rt,sum=0;
ll find(ll x){
if(x==fa[x]) return x;
return fa[x]=find(fa[x]);
}
void unionn(ll x,ll y){
int a=find(x),b=find(y);
fa[a]=b;
}
int main(){
scanf("%lld%lld",&n,&m);
for(ll i=1;i<=n;i++) fa[i]=i;
for(ll i=1,u,v;i<=m;i++){
scanf("%lld%lld",&u,&v);
if(u!=v){
unionn(u,v);
du[v]++,du[u]++;
}else tot_c++;
du2[v]++,du2[u]++;
}
for(ll i=1;i<=n;i++){
if(du2[i]){
rt=find(i);
break;
}
}
for(ll i=1;i<=n;i++){
if(rt!=find(i)&&du2[i]){
printf("0\n");
return 0;
}
}
for(ll i= 1;i<=n;i++)
ans+=du[i]*(du[i]-1)/2,sum+=du[i];
sum/=2;
ans+=tot_c*sum;
ans+=tot_c*(tot_c-1)/2;
printf("%lld\n",ans);
return 0;
}
ps:对于需要开long long的题我都是把所有变量全变成long long类型
HZOI2019 星际旅行 欧拉路的更多相关文章
- 星际旅行(欧拉路,欧拉回路)(20190718 NOIP模拟测试5)
瞎搞了一个ans+=du*(du-1)/2 wa20分,好桑心(话外音:居然还有二十分,出题人太周到了) 还是判欧拉路 题解没太仔细想,感觉还是kx的思路明白 具体就是:因为每条边要走两遍,可以把一条 ...
- [CSP-S模拟测试]:星际旅行(欧拉路)
题目传送门(内部题4) 输入格式 第一行两个整数$n,m$,表示行星和虫洞的数量.接下来$m$行,每行两个整数$u,v$,表示存在一个双向虫洞直接连接$u$和$v$.每一个虫洞最多会被描述一次. 输出 ...
- 洛谷P1341 无序字母对[无向图欧拉路]
题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...
- POJ1386Play on Words[有向图欧拉路]
Play on Words Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 11846 Accepted: 4050 De ...
- hdu1161 欧拉路
欧拉路径是指能从一个点出发能够“一笔画”完整张图的路径:(每条边只经过一次而不是点) 在无向图中:如果每个点的度都为偶数 那么这个图是欧拉回路:如果最多有2个奇数点,那么出发点和到达点必定为该2点,那 ...
- UVA10054The Necklace (打印欧拉路)
题目链接 题意:一种由彩色珠子组成的项链.每个珠子的两半由不同的颜色组成.相邻的两个珠子在接触的地方颜色相同.现在有一些零碎的珠子,需要确定他们是否可以复原成完整的项链 分析:之前也没往欧拉路上面想, ...
- 洛谷 P1341 无序字母对 Label:欧拉路 一笔画
题目描述 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个字母的字符串使得每个字母对都在这个字符串中出现. 输入输出格式 输入格式: 第一行输入一 ...
- POJ 1637 Sightseeing tour (混合图欧拉路判定)
Sightseeing tour Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 6986 Accepted: 2901 ...
- hihocoder 1181 欧拉路.二
传送门:欧拉路·二 #1181 : 欧拉路·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上一回中小Hi和小Ho控制着主角收集了分散在各个木桥上的道具,这些道具其 ...
随机推荐
- 给大家介绍一下linux系统高级命令
输出重定向(mip.0834jl.com) ;覆盖文件内容 回声' 123 ' 测试;覆盖原始内容 回声' 123 ' 测试;原始存在(共存) echo 'ken2 '(www.jl0834.com) ...
- MR 原理
MapReduce的执行步骤: 1.Map任务处理 1.1 读取HDFS中的文件.每一行解析成一个<k,v>.每一个键值对调用一次map函数. <0,h ...
- Storm 测试
本文将学习如何使用java创建Storm拓扑 Storm集群的组件 Storm集群类似于Hadoop集群,只不过 Hadoop 上运行"MapReduce jobs", Storm ...
- winform程序捕获全局异常,对错误信息写入日志并弹窗
使用场景:在winform程序中如果没对方法进行try catch操作,若方法内出错,则整个程序报错并退出,如下图 如果程序已在客户手中,若没对错误的详细信息进行拍照,我们则不知道错误原因是什么.我们 ...
- Linux 通用数据结构说明
device_driver include/linux/device.h struct device_driver { const char * name; /* 驱动名称 * ...
- Luogu P2717 寒假作业(平衡树)
P2717 寒假作业 题意 题目背景 \(zzs\)和\(zzy\)正在被寒假作业折磨,然而他们有答案可以抄啊. 题目描述 他们共有\(n\)项寒假作业.\(zzy\)给每项寒假作业都定义了一个疲劳值 ...
- 233 Matrix
233 Matrix 有一\(n\times m\)的矩阵\(\{a\}\),定义\(a[0][0]=0,a[0][1]=233,a[0][2]=2333,a[0][3]=23333...\),然后给 ...
- jmeter做bbs作业时提示404错误
在用jemter做bbs作业时候,注册成功后会跳转到主页,在写主页的脚本的时候,将fiddler抓到的url复制到路径下方“/bbs/forum.php”,但是第一次复制的时候在/bbs/forum. ...
- 容斥原理——hdu3208
和hdu2204有点像 这题要特别注意精度问题,如pow的精度需要自己搞一下,然后最大的longlong可以设为1<<31 /* 只要求[1,n]范围内的sum即可 那么先枚举幂次k[1, ...
- duilib教程之duilib入门简明教程1.前言
关于duilib的介绍就不多讲了,一来不熟,二来小伙伴们想必已经对比了多个界面库,也无需赘述.下面进入正题: 不看广告看疗效! 已有众多知名公司采用duilib做为界面库,如华为网盘.PPS(P ...