题意简述

给定一个图 求至少添加多少条边使得它存在奇环 并求出添加的方案数

(注意不考虑自环)

-----------------------------------------------------------------------------

一道二分图染色的讨论题

比赛时只会用二分图染色判断树以及偶环 忘记用这个来判奇环。。。

二分图染色这种联赛知识点的题目现在也不会写了。。。

------------------------------------------------------------------------------

我们可以按需要添加边的条数来讨论这题

首先讨论添加边条数为3——即原原图边数m为0时

$ans=n*(n-1)*(n-2)/6$

再讨论添加边条数为2——即原图中所有边都没有公共端点/所有点度数<=1 时

$ans=m*(n-2)$

再讨论添加边数为0——即原图中存在奇环时

$ans=1$

最后讨论添加边数为1——即原图中只有树以及偶环

$ans=\sum(white[i]-1)*white[i]/2+(black[i]-1)*black[i]/2$

其实思路清晰后实现起来就很容易了

#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#define rep(i,n) for(int i=1;i<=n;++i)
#define imax(x,y) (x>y?x:y)
#define imin(x,y) (x<y?x:y)
using namespace std;
const int N=;
int firste[N],nexte[N<<],v[N<<];
int color[N],fa[N],bl[N],wh[N],degree[N];
int n,m,e=,flag=;
long long ans=;
void build_edge(int x,int y)
{
++e;
nexte[e]=firste[x];
firste[x]=e;
v[e]=y;
}
void dfs(int u,int c,int f)
{
color[u]=c;
fa[u]=f;
if(c&)++bl[f];
else ++wh[f];
for(int p=firste[u];p;p=nexte[p])
if(!color[v[p]])dfs(v[p],-c,f);
else if(color[v[p]]==color[u])
{
flag=;
return;
}
}
int main()
{
int x,y;
scanf("%d%d",&n,&m);
if(!m)
{
ans=(long long)n*(n-)*(n-)/;
printf("3 %I64d",ans);
return ;
}
rep(i,m)
{
scanf("%d%d",&x,&y);
build_edge(x,y);
build_edge(y,x);
++degree[x];
++degree[y];
if(degree[x]>||degree[y]>)flag=;
}
if(flag)
{
ans=(long long)m*(n-);
printf("2 %I64d",ans);
return ;
}
int cnt=;
rep(i,n)
if(!color[i])
{
dfs(i,,++cnt);
if(flag)
{
printf("0 1");
return ;
}
}
rep(i,cnt)
ans+=(long long)(wh[i]-)*wh[i]/+(long long)(bl[i]-)*bl[i]/;
printf("1 %I64d",ans);
return ;
}

codeforces 557D Vitaly and Cycle的更多相关文章

  1. CodeForces - 557D Vitaly and Cycle(二分图)

    Vitaly and Cycle time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  2. codeforces 557D. Vitaly and Cycle 二分图染色

    题目链接 n个点, m条边, 问最少加几条边可以出现一个奇环, 在这种情况下, 有多少种加边的方式. 具体看代码解释 #include<bits/stdc++.h> using names ...

  3. Codeforces Round #311 (Div. 2) D. Vitaly and Cycle 图论

    D. Vitaly and Cycle Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/557/p ...

  4. codeforces 557 D. Vitaly and Cycle 组合数学 + 判断二分图

    D. Vitaly and Cycle       time limit per test 1 second memory limit per test 256 megabytes input sta ...

  5. Codeforces Round #311 (Div. 2) D. Vitaly and Cycle 奇环

    题目链接: 点这里 题目 D. Vitaly and Cycle time limit per test1 second memory limit per test256 megabytes inpu ...

  6. Codeforces Round #311 (Div. 2) D - Vitaly and Cycle

    D. Vitaly and Cycle time limit per test 1 second memory limit per test 256 megabytes input standard ...

  7. 【34.57%】【codeforces 557D】Vitaly and Cycle

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  8. Codeforces Round #311 (Div. 2) D - Vitaly and Cycle(二分图染色应用)

    http://www.cnblogs.com/wenruo/p/4959509.html 给一个图(不一定是连通图,无重边和自环),求练成一个长度为奇数的环最小需要加几条边,和加最少边的方案数. 很容 ...

  9. codeforces 518A. Vitaly and Strings

    A. Vitaly and Strings time limit per test 1 second memory limit per test 256 megabytes input standar ...

随机推荐

  1. Leapin' Lizards [HDU - 2732]【网络流最大流】

    题目链接 网络流直接最大流就是了,只是要拆点小心一个点的流超出了原本的正常范围才是. #include <iostream> #include <cstdio> #includ ...

  2. ichunqiu在线挑战--网站综合渗透实验 writeup

    挑战链接:http://www.ichunqiu.com/tiaozhan/111 知识点:后台弱口令,md5破解,SQL Injection,写一句话木马,敏感信息泄露, 提权,登陆密码破解 这个挑 ...

  3. Reinforcement Learning for Self Organization and Power Control of Two-Tier Heterogeneous Networks

    R. Amiri, M. A. Almasi, J. G. Andrews and H. Mehrpouyan, "Reinforcement Learning for Self Organ ...

  4. Spring cloud学习--Zuul01

    Zuul解决的问题 作为系统的统一入口,屏蔽了系统内部各个微服务的细节 可以与微服务治理框架结合,实现自动化的服务实例维护以及负载均衡的路由转发 实现接口权限校验与微服务业务逻辑的解耦 搭建Zuul服 ...

  5. MySQL数据类型-整型

    ​ MySQL支持SQL标准整数类型integer(或INT)和SMALLINT.作为标准的扩展,MySQL还支持整数类型TINYINT.MEDIUMINT和BIGINT. 类型 所占字节 有符号最小 ...

  6. Java负整数的左移、右移、无符号右移

    转自  Java负整数的左移.右移.无符号右移 Java负整数的左移.右移.无符号右移.正数的位移没有涉及到符号,而且正数的原码.反码.补码都是一样的,所以相对简单,但是对于负整数的位移,往往容易混淆 ...

  7. PHP实现上传文件到服务器

    <?php /**************************** *** 功能:上传文件到服务器 ****************************/ session_start() ...

  8. 33.Jump Game(跳步游戏)

    Level:   Medium 题目描述: Given an array of non-negative integers, you are initially positioned at the f ...

  9. .net core 简单集成JWT报No authenticationScheme was specified, and there was no DefaultChallengeScheme found错误

    #region JWT 认证 services .AddAuthentication(JwtBearerDefaults.AuthenticationScheme) //.AddCustomAuth( ...

  10. 没有找到mspdb80.dll,因此这个应用程序未能启动...问题解决

    这里主要针对使用link.exe进行SIG文件制作时,报错. 首先下载,mspdb80.dll:https://www.lanzous.com/i59dgfi 将dll文件移动到我的电脑(32位)C: ...