hdu6311( 2018 Multi-University Training Contest 2)
http://acm.hdu.edu.cn/showproblem.php?pid=6311
从dls思路中,我整理一下自己的思路:
1、首先也是建图
2、建图结束后,一个dfs查找联通块和度数为奇数的点
从第二对奇数度点开始给奇数度点对开始加辅助边(>2*m+1)
3. 加辅助边后,一个dfs搜索所有的奇数度顶点,如果碰到一个虚边,则res+2;
最后一笔画的个数为max(res/2,1)
/*hdu6311cover
题意:给出一张无向图,问多少次一笔画能覆盖整张图。
dls的思路:
1.对给出的数据建图
2.搜索图中的联通块和度为奇数的点
3.在联通块内的奇数对额外添加虚边(添加奇数点个数/2条边)
4.dfs得到最后结果
一张联通图n笔画完,则n=max(|degree(奇数)|/2,1)
每次添加一条边,则度数+2
当图上至多只有一对奇数度的点时,便可以一笔走过所有的边
删除额外添加的边(序号为>2*m+1)得到结果
*/
#include<bits/stdc++.h>
using namespace std;
const int MAXN=1e5+10;
struct Edge
{
int to,next;//to保存终点,next保存邻接的边
bool able;
}edge[MAXN<<2];
int n,m;
int Degree[MAXN];//每个点的度
int Head[MAXN];//每个点的最后一条边加入的边的序号
int cnt;//边的序号
int res;//一共找到的路径
bool vis[MAXN];
vector<int>st;//保存一个连通块中度为奇数的点
vector<int>road[MAXN];
void add(int u,int v)
{
edge[++cnt].next=Head[u];
edge[cnt].to=v;
edge[cnt].able=true;
Head[u]=cnt;
++Degree[u];
}
void add_edge(int u,int v)
{
add(u,v);
add(v,u);
}
//找到联通块和奇数点的度
void dfs(int s)
{
vis[s]=true;
if(Degree[s]&1)st.push_back(s);
for(int i=Head[i];i;i=edge[i].next)
{
if(!vis[edge[i].to])dfs(edge[i].to);
}
}
void dfs2(int s)
{
for(int i=Head[s];i;i=edge[i].next)
{
if(edge[i].able)
{
edge[i].able=edge[i^1].able=false;
dfs2(edge[i].to);
if(i>2*m+1)++res;//说明此边是由奇数度添加得到的,所以这条回路结束
else
{
road[res].push_back(i/2*(2*(i&1)-1));
}
}
}
}
int main()
{
int u,v;
while(cin>>n>>m)
{
cnt=1;res=0;
for(int i=0;i<m;i++)
{
scanf("%d%d",&u,&v);
add_edge(u,v);
}
for(int i=1;i<=n;i++)
{
if(!vis[i]&&Degree[i])
{
dfs(i);//找到联通块和奇数度的点
if(st.empty())
{
st.push_back(i);
st.push_back(i);
}
for(int j=2;j<st.size();j+=2)
{//从第二对开始的奇数度的点添加一条双向边
add_edge(st[j],st[j+1]);
}
res++;
dfs2(st[0]);
st.clear();
}
}
printf("%d\n",res);
for(int i=1;i<=res;i++)
{
printf("%d",road[i].size());
for(int j=0;j<road[i].size();j++)
{
printf(" %d",road[i][j]);
}
puts("");
road[i].clear();
}
for(int i=1;i<=n;i++)
{
vis[i]=false;
Head[i]=0;
Degree[i]=0;
}
return 0;
}
}
hdu6311( 2018 Multi-University Training Contest 2)的更多相关文章
- ( 2018 Multi-University Training Contest 2)
2018 Multi-University Training Contest 2) HDU 6311 Cover HDU 6312 Game HDU 6313 Hack It HDU 6314 Mat ...
- HDU4888 Redraw Beautiful Drawings(2014 Multi-University Training Contest 3)
Redraw Beautiful Drawings Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- HDU 5726 GCD (2016 Multi-University Training Contest 1)
Time Limit: 5000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64u Description Give y ...
- HDU 4897 Little Devil I(树链剖分)(2014 Multi-University Training Contest 4)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4897 Problem Description There is an old country and ...
- HDU 4906 Our happy ending(2014 Multi-University Training Contest 4)
题意:构造出n个数 这n个数取值范围0-L,这n个数中存在取一些数之和等于k,则这样称为一种方法.给定n,k,L,求方案数. 思路:装压 每位 第1为表示这种方案能不能构成1(1表示能0表示不能) ...
- (2018 Multi-University Training Contest 3)Problem D. Euler Function
//题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6322 //题目大意:给定 k,求第 k 小的数 n,满足 φ(n) 是合数.显然 φ(1) = 1 ...
- hdu6315( 2018 Multi-University Training Contest 2)
bryce1010模板 http://acm.hdu.edu.cn/showproblem.php?pid=6315 /*hdu 1007 首先我们在建立线段树之前应该思考的是线段树的节点维护一个什么 ...
- hdu6314( 2018 Multi-University Training Contest 2)
bryce1010模板 http://acm.hdu.edu.cn/showproblem.php?pid=6314 ----. 又是一个数学题! 这个题使用容斥原理解决的,现场看dls推公式. 我也 ...
- hdu6313( 2018 Multi-University Training Contest 2)
bryce1010模板 http://acm.hdu.edu.cn/showproblem.php?pid=6313 参考dls的讲解: 以5*5的矩阵为例: 后一列分别对前一列+0+1+2+3+4操 ...
随机推荐
- 浅淡!important对CSS的重要性
SS中的!important是一个非常重要的属性,有时候发挥着非常大的作用,52CSS.com这方面的知识并不是非常多,我们看下面的文章,对它作比较感观的了解. 前几天写一些CSS代码的时候又难为我了 ...
- include vector 编译出错VC++
error C2665: “operator new” : 5个重载中没有一个可以转换参数1(从“const char [71]”类型)这个错误是怎么回事啊,搜索了整个项目好像没有可疑的new操作阿. ...
- HDU2896 病毒侵袭 —— AC自动机
题目链接:https://vjudge.net/problem/HDU-2896 病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit ...
- Git学习笔记 - Git安装
Git安装(Windows) 从 https://git-for-windows.github.io/ 下载Git,下载完成,双击安装,一路选择默认设置即可. 注意:选择使用git的命令行模式,选择默 ...
- RequireJS 配置理解
RequireJS 配置: 1.首先加载RequireJS文件 <script src="//cdn.bootcss.com/require.js/2.1.22/require.js& ...
- 51nod最长递增路径:(还不错的图)
一个无向图,可能有自环,有重边,每条边有一个边权.你可以从任何点出发,任何点结束,可以经过同一个点任意次.但是不能经过同一条边2次,并且你走过的路必须满足所有边的权值严格单调递增,求最长能经过多少条边 ...
- BZOJ_1044_[HAOI2008]木棍分割_二分答案+DP+单调队列
BZOJ_1044_[HAOI2008]木棍分割_二分答案+DP Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个 ...
- yolo原理学习
1.[yolov1] 第一步:将图像划分为S*S的栅格(grid cell),这里分成了7*7的grid cell.栅格的任务是:检测中心落在该栅格中的物体(注意,栅格中心未必与物体的中心重合, ...
- starUML安装与破解
安装包百度云: 链接:https://pan.baidu.com/s/1oF_DH7Xh6yun6fFUDB2H3w 密码:1z7e 破解步骤:1. 首先打开你的starUML安装目录,并找到Lice ...
- activeMQ:java消息机制初试(一)
前言:自打学习编程以来,就知道activeMQ这么个东西,但是仅仅限于只知其名,不闻其详.现在加入到新的项目组,项目中使用了这个.现在想重新去学习和了解.最后整合成一个完成的demo,在网上看的Dem ...