hihoCoder #1127 : 二分图二·二分图最小点覆盖和最大独立集

时间:2023-03-09 03:08:28
hihoCoder #1127 : 二分图二·二分图最小点覆盖和最大独立集

#1127 : 二分图二·二分图最小点覆盖和最大独立集

Time Limit:10000ms
Case Time Limit:1000ms
Memory Limit:256MB

描述

在上次安排完相亲之后又过了挺长时间,大家好像都差不多见过面了。不过相亲这个事不是说那么容易的,所以Nettle的姑姑打算收集一下之前的情况并再安排一次相亲。所以现在摆在Nettle面前的有2个问题:

1.姑姑想要了解之前所有相亲的情况。对于任一个一次相亲,只要跟参与相亲的两人交流就可以得到这次相亲的情况。如果一个人参加了多次相亲,那么跟他交流就可以知道这几次相亲的情况。那么问题来了,挖掘技术到底哪家强姑姑最少需要跟多少人进行交流可以了解到所有相亲的情况。

问题1解答

2.因为春节快要结束了,姑姑打算给这些人再安排一次集体相亲。集体相亲也就是所有人在一起相亲,不再安排一对一对的进行相亲。但是姑姑有个条件,要求所有参与相亲的人之前都没有见过。也就是说在之前的每一次相亲中的两人不会被同时邀请来参加这次集体相亲。那么问题又来了,姑姑最多可以让多少人参与这个集体相亲。

问题2解答

输入

第1行:2个正整数,N,M(N表示点数 2≤N≤1,000,M表示边数1≤M≤5,000)
第2..M+1行:每行两个整数u,v,表示一条无向边(u,v)

输出

第1行:1个整数,表示最小点覆盖数
第2行:1个整数,表示最大独立集数

Sample Input
5 4
3 2
1 3
5 4
1 5
Sample Output
2
3 解题:极大独立集与最小点覆盖互补。。。
在二分图中有:最小点覆盖 = 最大匹配
 /*
@author: Lev
@date:
*/
#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstring>
#include <string>
#include <cstdlib>
#include <algorithm>
#include <map>
#include <set>
#include <queue>
#include <climits>
#include <deque>
#include <sstream>
#include <fstream>
#include <bitset>
#include <iomanip>
#define LL long long
#define INF 0x3f3f3f3f using namespace std;
const int maxn = ;
vector<int>g[maxn];
int n,m,link[maxn];
bool used[maxn];
bool dfs(int u){
for(int i = g[u].size()-; i >= ; --i){
if(!used[g[u][i]]){
used[g[u][i]] = true;
if(link[g[u][i]] == - || dfs(link[g[u][i]])){
link[g[u][i]] = u;
link[u] = g[u][i];
return true;
}
}
}
return false;
}
int main() {
while(~scanf("%d %d",&n,&m)) {
for(int i = ; i < maxn; ++i) {
g[i].clear();
link[i] = -;
used[i] = false;
}
for(int i = ; i < m; ++i) {
int u,v;
scanf("%d %d",&u,&v);
g[u].push_back(v);
g[v].push_back(u);
}
int ans = ;
for(int i = ; i <= n; ++i)
if(link[i] == -){
memset(used,false,sizeof(used));
ans += dfs(i);
}
printf("%d\n%d\n",ans,n-ans);
}
return ;
}