hdu多校2C
题意:找多条路径覆盖所有的边,求最小路径数,要求输出路径
题解:新建一个点n+1,所有奇点向它连边,然后跑欧拉回路,最后把新加的边删去,一段连续的边就是一条路径
= =但是由于太久没写欧拉回路以及之前的板子有点问题,导致比赛时没做出来
还有一个坑点是,明明题目里说了没有重边,我规定不能访问父亲居然就wa了!!!!
//#pragma comment(linker, "/stack:200000000")
//#pragma GCC optimize("Ofast,no-stack-protector")
//#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
//#pragma GCC optimize("unroll-loops")
#include<bits/stdc++.h>
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define pi acos(-1.0)
#define ll long long
#define vi vector<int>
#define mod 1000000007
#define ld long double
#define C 0.5772156649
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#define pll pair<ll,ll>
#define pil pair<int,ll>
#define pli pair<ll,int>
#define pii pair<int,int>
#define cd complex<double>
#define ull unsigned long long
#define base 1000000000000000000
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
#define fio ios::sync_with_stdio(false);cin.tie(0)
inline void add(ll &a,ll b){a+=b;if(a>=mod)a-=mod;}
inline void sub(ll &a,ll b){a-=b;if(a<0)a+=mod;}
inline ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
inline ll qp(ll a,ll b){ll ans=1;while(b){if(b&1)ans=ans*a%mod;a=a*a%mod,b>>=1;}return ans;}
using namespace std;
const double eps=1e-8;
const ll INF=0x3f3f3f3f3f3f3f3f;
const int N=200000+10,maxn=400000+10,inf=0x3f3f3f3f;
struct edge{
int to,Next,id;
}e[maxn];
int cur[N];
int cnt,head[N],deg[N];
vi s[N];
int res,n,m,sum;
bool ban[maxn];
inline void init()
{
cnt=res=sum=0;
for(int i = 1; i <= n + 1; i++) {
head[i] = -1;
deg[i] = 0;
}
}
inline void add(int u,int v,int id)
{
e[cnt].to=v;
e[cnt].Next=head[u];
e[cnt].id=id;
ban[cnt] = false;
head[u]=cnt++;
e[cnt].to=u;
e[cnt].Next=head[v];
e[cnt].id=id;
ban[cnt] = false;
head[v]=cnt++;
}
void dfs(int u,int f)
{
// cout << u << " " << f << endl;
// for(int i=head[u];~i;i=e[i].Next)
while(head[u] != -1)
{
int i = head[u];
int x=e[i].to;
head[u] = e[i].Next;
if(!ban[e[i].id])
{
ban[e[i].id]=1;
dfs(x,u);
if(u!=n+1)
{
if(x!=n+1)
{
s[res].pb(i&1?-e[i].id:e[i].id);
}
else
{
if((int)s[res].size()!=0)res++;
}
}
}
}
}
int main()
{
int a, b;
while(~scanf("%d%d",&n, &m))
{
init();
for(int i=1;i<=m;i++)
{
scanf("%d%d", &a, &b);
add(a,b,i);
deg[a]++,deg[b]++;
}
int te=m;
for(int i=1;i<=n;i++)
if(deg[i]&1)
add(i,n+1,++te);
dfs(n+1,-1);
if((int)s[res].size()!=0)res++;
for(int i=1,j;i<=n;i++)
while((j=head[i])!=-1){
head[i] = e[j].Next;
if(!ban[e[j].id])
{
dfs(i,-1);
if(s[res].size()!=0)res++;
}
}
printf("%d\n",res);
for(int i=0;i<res;i++)
{
printf("%d",s[i].size());
for(int j=s[i].size() - 1;j >= 0;--j)
printf(" %d",s[i][j]);
puts("");
s[i].clear();
}
// for(int i = 1; i <= n; i++) printf("%d ", head[i]);
}
return 0;
}
/********************
6 6
1 2
2 3
3 4
2 5
3 5
2 6
6 6
1 2
2 3
1 3
4 5
5 6
4 6
31 36
12 28
12 27
27 28
15 26
15 25
25 26
17 23
17 24
23 24
20 21
20 22
21 22
29 30
30 31
29 31
1 2
2 3
3 4
1 4
4 5
4 6
5 7
6 7
7 8
8 9
9 10
10 11
11 12
10 14
14 15
10 13
13 16
16 17
13 18
18 19
19 20
8 7
1 2
2 3
3 4
4 8
5 6
6 7
7 4
********************/
hdu多校2C的更多相关文章
- 2018 HDU多校第四场赛后补题
2018 HDU多校第四场赛后补题 自己学校出的毒瘤场..吃枣药丸 hdu中的题号是6332 - 6343. K. Expression in Memories 题意: 判断一个简化版的算术表达式是否 ...
- 2018 HDU多校第三场赛后补题
2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...
- 2015 HDU 多校联赛 5363 Key Set
2015 HDU 多校联赛 5363 Key Set 题目: http://acm.hdu.edu.cn/showproblem.php? pid=5363 依据前面给出的样例,得出求解公式 fn = ...
- 2015 HDU 多校联赛 5317 RGCDQ 筛法求解
2015 HDU 多校联赛 5317 RGCDQ 筛法求解 题目 http://acm.hdu.edu.cn/showproblem.php? pid=5317 本题的数据量非常大,測试样例多.数据 ...
- [HDU多校]Ridiculous Netizens
[HDU多校]Ridiculous Netizens 点分治 分成两个部分:对某一点P,连通块经过P或不经过P. 经过P采用树形依赖背包 不经过P的部分递归计算 树型依赖背包 v点必须由其父亲u点转移 ...
- 【杂题总汇】HDU多校赛第十场 Videos
[HDU2018多校赛第十场]Videos 最后一场比赛也结束了…… +HDU传送门+ ◇ 题目 <简要翻译> 有n个人以及m部电影,每个人都有一个快乐值.每场电影都有它的开始.结束时间和 ...
- hdu多校1002 Balanced Sequence
Balanced Sequence Time Limit: / MS (Java/Others) Memory Limit: / K (Java/Others) Total Submission(s) ...
- HDU多校(Distinct Values)
Problem Description Chiaki has an array of n positive integers. You are told some facts about the ar ...
- hdu多校6
这个场要恶心死我了.. 1001 积分题,不要四舍五入 //#pragma comment(linker, "/stack:200000000") //#pragma GCC op ...
随机推荐
- python excel练习:新建sheet、修改名称、设定颜色、打印sheet名称,复制,保存
练习: 新建一个sheet 设定一个sheet的插入位置 修改sheet的名称为‘xiaxiaoxu’ 设定该sheet的背景标签的颜色 获取全部sheet的名称,打印每个sheet的名称 copy一 ...
- 05:ModelForm 数据验证 & 生成html & 数据库操作
目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...
- 20145307陈俊达《网络对抗》Exp5 MSF基础应用
20145307陈俊达<网络对抗>Exp5 MSF基础应用 基础问题回答 用自己的话解释什么是exploit,payload,encode? exploit就相当于是载具,各式各样的漏洞在 ...
- String和int互相转换,String转float
String-->int int a=Integer.parseIn(str); int-->String String s= a+""; String-->fl ...
- C# 获取枚举的描述属性
在使用枚举类型时,我们需要取名称和值,甚至有时候还需要取枚举类型的描述.通过反射,我们能获取到枚举类型的描述属性. 首先我们需要给枚举类型添加描述属性(属性都没有是不可能取到的),[Descripti ...
- Python3基础 try-多个指定except与不指定except 简单示例
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- Python3基础 父,子类普通方法重名 子类方法覆盖父类方法
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- poj 8469 特殊密码锁
a:特殊密码锁 总时间限制: 1000ms 内存限制: 1024kB 描述 有一种特殊的二进制密码锁,由n个相连的按钮组成(n<30),按钮有凹/凸两种状态,用手按按钮会改变其状态. 然而让人头 ...
- Leetcode ——Partition Equal Subset Sum
Question Given a non-empty array containing only positive integers, find if the array can be partiti ...
- Ambari安装指南
一.准备工作 l 基本工具 1) 安装epel,epel是一个提供高质量软件包的项目.先检查主机上是否安装: rpm -q epel-release 2) 如果没有安装,使用rpm命令安装: rpm ...