题意

https://vjudge.net/problem/CodeForces-862B

给出n个点,n-1条边,求再最多再添加多少边使得二分图的性质成立

思路

因为题目是求的最多添加多少边,所以可以对树01染色,然后让每个0点连上所有的黑点,一共有0的个数*1的个数条边。再减去树的n-1条边即可。

代码

#include<bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
#define ll long long
const int N=200005;
const int mod=1e9+7;
const double eps=1e-8;
const double PI = acos(-1.0);
#define lowbit(x) (x&(-x))
vector<int> g[N];
ll col[N],num[2];
void dfs(int u,int fa)
{
    for(int v:g[u])
    {
        if(v==fa)
            continue;
        col[v]=col[u]^1;
        num[col[v]]++;
        dfs(v,u);
    }
}
int main()
{
    std::ios::sync_with_stdio(false);
    int n;
    cin>>n;
    for(int i=1; i<n; i++)
    {
        int u,v;
        cin>>u>>v;
        g[u].push_back(v);
        g[v].push_back(u);
    }
    num[0]++;
    col[1]=0;
    dfs(1,0);
    cout<<num[0]*num[1]-(n-1)<<endl;
    return 0;
}

  

02-11 09:57