[TIOJ] 1089. Asteroids

題目連結:http://tioj.infor.org/problems/1089
TIOJ 1253. 砲打皮皮一模一樣的題目,可以轉成二分圖最小點覆蓋,然後用最大匹配的做法去做,詳細可以去看那篇的題解
#include <bits/stdc++.h>
using namespace std;
#define N 500

vector<int> X[N+5],Y[N+5];
int fX[N+5], fY[N+5];
bitset<N+5> walked;

bool dfs(int);

int main(){
	ios_base::sync_with_stdio(0);cin.tie(0);
	int n,k;cin>>n>>k;
	for(int i=1;i<=n;++i)fX[i]=fY[i]=-1;
	while(k--){
		int s,e;cin>>s>>e;
		X[s].push_back(e);
		Y[e].push_back(s);
	}
	int ans=0;
	for(int i=1;i<=n;i++){
		walked.reset();
		if(dfs(i))ans++;
	}
	cout<<ans;
	return 0;
}

bool dfs(int x){
	for(auto i:X[x]){
		if(walked[i])continue;
		walked[i]=1;
		if(fY[i]==-1||dfs(fY[i])){
			fY[i]=x;fX[x]=i;
			return 1;
		}
	}
	return 0;
}

留言

這個網誌中的熱門文章

[TIOJ] 1094. C.幼稚國王的獎賞

[Codeforces] 731F. Video Cards

[IOJ] 19. 啦啦啦