jzoj5806
我們發現,如果有奇環顯然無解,因為我們每一次合併一個奇環,一定會產生一個偶環和一個更小的奇環,最終會形成一個三元環而無法合併
所以,這個圖需要是一個二分圖,需要進行二染色
然後把這個圖所有的偶環找出來,答案就是這些偶環的長度除以2,這樣子很難
然而我們發現,偶環上的任意兩個點的最大距離的最短值一定等於偶環長度除以2,所以找出上一問等價于找出最短路的最大值,進行bfs即可
但是有可能有多個聯通塊,所以我們可以尋找所有聯通塊中的最短路徑的最大值即可
代碼:
#include<bits/stdc++.h>
using namespace std;
int v[200010],nxt[200010],h[100010],ec,n,m,col[100010],vis[100010],st[100010],ct,ok,d[1010],p[100010],r;
void add(int x,int y){v[++ec]=y;nxt[ec]=h[x];h[x]=ec;}
void dfs(int x){
vis[x]=1;st[++ct]=x;
for(int i=h[x];i;i=nxt[i]){
if(!vis[v[i]]){
col[v[i]]=!col[x];
dfs(v[i]);
}
else if(vis[v[i]]&&col[v[i]]==col[x])ok=0;
}
}
int main(){
freopen("merge.in","r",stdin);
freopen("merge.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++){
int x,y;
scanf("%d%d",&x,&y);
add(x,y);add(y,x);
}
for(int i=1;i<=n;i++)if(!vis[i]){
ok=1;int ans=0;
dfs(i);
if(!ok){
printf("-1");
return 0;
}
queue<int>q;
for(int j=1;j<=ct;j++){
memset(d,127,sizeof(d));
q.push(st[j]);
d[st[j]]=0;
while(!q.empty()){
int x=q.front();q.pop();
ans=max(ans,d[x]);
for(int k=h[x];k;k=nxt[k])
if(d[v[k]]>d[x]+1){
d[v[k]]=d[x]+1;
q.push(v[k]);
}
}
}
r+=ans;
ct=0;
}
printf("%d",r);
}
jzoj5806的更多相关文章
- [Solution] JZOJ-5806 简单的操作
[Solution] JZOJ-5806 简单的操作 题面 Description 从前有个包含n个点,m条边,无自环和重边的无向图. 对于两个没有直接连边的点u;v,你可以将它们合并.具体来说,你可 ...
随机推荐
- 使用jmeter工具测试上传接口
1.方法选择post:上传都是post上传. 2.路径输入正确的上传接口路径,并勾选Use multipart/form-data for POST 3.添加文件,文件路径尽量不要有中文,防止编码问题 ...
- linux下添加用户并赋予root权限
1.添加用户,首先用adduser命令添加一个普通用户,命令如下: #adduser tommy //添加一个名为tommy的用户#passwd tommy //修改密码Changing pass ...
- Byte字节与位
位(bit)字节(byte)一字节是8位所以2Byte是16位二进制
- Zookeeper 系列(四)ZKClient API
Zookeeper 系列(四)ZKClient API 环境准备: <dependency> <groupId>com.101tec</groupId> <a ...
- Exce行列变色
- 【转】ORACLE 表空间扩展方法
转载地址:http://blog.itpub.net/28950170/viewspace-763139/ 第一步:查看表空间的名字及文件所在位置: select tablespace_name, f ...
- Redis配置总结
一:常用配置 1.bind,格式为bind 127.0.0.1:这个是很重要的配置,如果bind 127.0.0.1则外部网络是访问不了的(如果外部网络要访问还要开放端口) 2.port,格式为por ...
- PS各个工具的字母快捷键和英文全名
选框-Marquee(M) 移动-move(V) 套索-Lasso(L) 魔棒-Wand(W) 喷枪-injection lance (J) 画笔-Brush (B) 铅笔-pencil(N) 橡皮图 ...
- nlms_step_get
module nlms_step_get( rst , clk , nd , din01_i, din01_q, din02_i, din02_q, dou ...
- ubuntu18.04 编译安装 apache php
1. apache apache 需要依赖几个模块:apr, apr-util, pcre,也分别源码安装. 1.1 编译安装 1.1.1 apr apr-util 下载地址:http://apr.a ...