Description

​ 现在给你一张NN个点MM条边的连通图,我们保证N−1≤M≤NN−1≤M≤N,且无重边和自环。

​ 每一个点都有一种颜色,非黑即白。初始时,所有点都是白色的。

​ 想通过执行若干次某种操作的方式,来将所有的点变成黑色。操作方式如下:

​ 选择一对颜色相同的****相邻的节点(存在边直接连接彼此),将它们的颜色反转。即若原来都是白色,则都变成黑色,反之亦然。

​ 现在想知道,他能否通过执行这种操作以达到目的。如果可以,他还希望步数尽可能的少。

Input

​ 第一行有两个正整数NN和MM(2≤N≤1052≤N≤105,N−1≤M≤NN−1≤M≤N)

接下来MM行,每行2个正整数aa和bb(1≤a,b≤N1≤a,b≤N),表示每条边连接的两个点。

Output

​ 如果存在操作方案能达到目的,请输出最少操作次数。

否则,请输出−1−1

Sample Input

Sample Input 1
6 5
1 2
1 3
1 4
2 5
2 6 Sample Input 2
3 2
1 2
2 3 Sample Input 3
4 4
1 2
2 3
3 4
4 1 Sample Input 4
6 6
1 2
2 3
3 1
1 4
1 5
1 6

Sample Output

Sample Output 1
5 Sample Output 2
-1 Sample Output 3
2 Sample Output 4
7

HINT

​ 如第一个样例中,存在如下操作方案:

Sol

如果是一棵树,我们把深度为奇数的点赋值为1,偶数-1,然后判断总和是否为0即可。此时答案为\(\sum_{i=1}^{n}abs(s[i])\),\(s[i]\)表示子树和。证明:我们让子树变成0的最小操作次数就是绝对值,因为一次操作至多改变1。

如果是个基环树,那么我们判断这个环连的两个点深度是否同奇同偶,同的话每次能够且仅能够添加或者删除2个权值,这样的话我们判断sum是不是一个偶数,是的话我们把s[u]和s[v]减去sum/2,然后做一次树的做法即可。

如果不同,说明我们无法改变总和,只能通过这个边进行直接对于不同深度的传输,我们假设u的权值+x,v的权值-x(只是系数,x能是任何数字),然后我们进行系数的子树和,这样的话求出系数为1或者-1的所有点,这些点是要加上x的,剩下的直接取abs,加上x的地方我们把它系数置为1(改变数字的正负强制改变系数),然后丢进一个数组,排序后取中位数即为最优解。

Code

#include <bits/stdc++.h>
using namespace std;
int fa[100005],c[100005],d[100005],s[100005],g[100005],i,j,k,l,t,n,m,u,v,a,b,x,tot,num,vis[100005],ok;
long long ans;vector<int>e[100005];
void dfs1(int x,int y)
{
vis[x]=1;
for(int i=0;i<e[x].size();i++) if(e[x][i]!=y)
{
if(vis[e[x][i]]){u=x;v=e[x][i];if(c[u]==c[v]) ok=1;}
else{c[e[x][i]]=c[x]^1;dfs1(e[x][i],x);}
}
}
void dfs(int x,int y)
{
for(int i=0;i<e[x].size();i++) if(e[x][i]!=y&&!((x==u&&e[x][i]==v)||(x==v&&e[x][i]==u)))
dfs(e[x][i],x),d[x]+=d[e[x][i]],s[x]+=s[e[x][i]];
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) scanf("%d%d",&j,&k),e[j].push_back(k),e[k].push_back(j);
c[1]=1;dfs1(1,0);
for(int i=1;i<=n;i++) s[i]=c[i]?1:-1;
for(int i=1;i<=n;i++) num+=s[i];
if(m==n-1){if(num){printf("-1\n");return 0;}}
else
{
if(ok){if(abs(num%2)==1){printf("-1\n");return 0;}s[u]-=num/2;s[v]-=num/2;ans+=(long long)abs(num/2);}
else{if(num){printf("-1\n");return 0;}d[u]=1;d[v]=-1;}
}
dfs(1,0);
for(int i=1;i<=n;i++) if(!d[i]) ans+=(long long)abs(s[i]);else g[++tot]=-s[i];
g[++tot]=0;sort(g+1,g+tot+1);x=g[(tot+1)/2];
for(int i=1;i<=tot;i++) ans+=(long long)abs(g[i]-x);
printf("%lld\n",ans);
}

[agc004f]Namori 贪心的更多相关文章

  1. 2017国家集训队作业[agc004f]Namori

    2017国家集训队作业[agc004f]Namori 题意: 给你一颗树或环套树,树上有\(N\)个点,有\(M\)条边.一开始,树上的点都是白色,一次操作可以选择一条端点颜色相同的边,使它的端点颜色 ...

  2. AGC004F Namori 树形DP、解方程(?)

    传送门 因为不会列方程然后只会树上的,被吊打了QAQ 不难想到从叶子节点往上计算答案.可以考虑到可能树上存在一个点,在它的儿子做完之后接着若干颜色为白色的儿子,而当前点为白色,只能帮助一个儿子变成黑色 ...

  3. Atcoder:AGC004F Namori

    传送门 先考虑树,树是一个二分图. 看到是二分图并且每次是对两边的同色的点反色可以想到转化:让奇数层的点为黑,偶数为白,变成每次可以交换两个点的颜色. 把黑看成 \(-1\),白看成 \(1\),那么 ...

  4. [AGC004F] Namori

    Description 现在给你一张N个点M条边的连通图,我们保证N−1≤M≤N,且无重边和自环. 每一个点都有一种颜色,非黑即白.初始时,所有点都是白色的. "全"想通过执行若干 ...

  5. AtCoder AGC004F Namori (图论)

    题目链接 https://atcoder.jp/contests/agc004/tasks/agc004_f 题解 神仙题.. 首先考虑树的情况,树是二分图,因此假设我们对二分图进行黑白染色,那么操作 ...

  6. 贪心/构造/DP 杂题选做Ⅲ

    颓!颓!颓!(bushi 前传: 贪心/构造/DP 杂题选做 贪心/构造/DP 杂题选做Ⅱ 51. CF758E Broken Tree 讲个笑话,这道题是 11.3 模拟赛的 T2,模拟赛里那道题的 ...

  7. AtCoder刷题记录

    构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...

  8. NOIp模拟赛二十九

    又是受虐的一天呢~接下来四天都要打模拟赛QAQ 今日分数:0(100)+100+0=100 A题O(读入)结论题判断结果时没return 0被subtask卡成0分,喜提fstQAQ,B题DP,C题不 ...

  9. 【agc004F】Namori

    Portal -->agc004F Solution  好神仙的转化qwq ​  首先我们可以先考虑\(m=n-1\)的情况下,也就是树的情况下要怎么做  我们可以将这个问题转化一下:我们对这颗 ...

随机推荐

  1. Python实现阿里云短信推送

    本篇文章是使用Python的Web框架Django提供发送短信接口供前端调用,Python版本2.7 阿里云入驻.申请短信服务.创建应用和模板等步骤请参考:阿里云短信服务入门 1.下载sdk 阿里云短 ...

  2. 201671010140. 2016-2017-2 《Java程序设计》java学习第十一周

     java学习第十一周     本周,进行了java集合方面的知识,在博客园的帮助下,我的课前预习更有条理性,重点明确,本周的课堂反应明显更好了,首先,梳理一下本周知识点.  Collection   ...

  3. mysql-5.6.24-win32解决没有my.ini并且修改编码

    3.配置环境变量:新建一个系统变量: MYSQL_HOME, 值:D:\MySql\mysql5611  //这一步不做也行 4.修改MySql启动配置文件: 将安装目录下文件:my-default. ...

  4. 第五章 大数据平台与技术 第12讲 大数据处理平台Spark

    Spark支持多种的编程语言 对比scala和Java编程上节课的计数程序.相比之下,scala简洁明了. Hadoop的IO开销大导致了延迟高,也就是说任务和任务之间涉及到I/O操作.前一个任务完成 ...

  5. hive单节点数据倾斜解决方法

    一.现象 map/reduce程序执行时,reduce节点大部分执行完毕,但是有一个或者几个reduce节点运行很慢,导致整个程序的处理时间很长,这是因为某一个key的条数比其他key多很多(有时是百 ...

  6. etherboot无盘启动

    2001.10.30 吴峰光 本站提供对无盘启动的支持.本文就此作一简单介绍. 一.概述 无盘启动,更确切的说是网络启动,可算是最为轻松和简便的启动方式了. 目前还很少有人了解它,因为目前的软硬件条件 ...

  7. java基础知识汇总(持续更新中....)

    1.java四大特性:抽象.继承.封装,多态 构造函数: http://blog.csdn.net/qq_33642117/article/details/51909346 2.java数据基本类型: ...

  8. [C++] Pure Virtual Function and Abstract Class

    Pure Virtual Function Abstract Class

  9. [SoapUI] SoapUI命令行方式运行

    https://www.soapui.org/test-automation/running-from-command-line/functional-tests.html TestRunner Co ...

  10. hbase java api样例(版本1.3.1,新API)

    hbase版本:1.3.1 目的:HBase新API的使用方法. 尝试并验证了如下几种java api的使用方法. 1.创建表 2.创建表(预分区) 3.单条插入 4.批量插入 5.批量插入(客户端缓 ...