dicnicTLE了,求大佬帮看看
查看原帖
dicnicTLE了,求大佬帮看看
475143
gaojian2007楼主2022/12/4 18:59
#include<iostream>
#include<queue>
using namespace std;
int n,m,e;
int head[1005],to[200005],net[200005],w[200005],tot=1,cut[1005],dis[1005];
int s,t;
void add(int u,int v,int ww){
	net[++tot]=head[u];
	head[u]=tot;
	cut[u]=tot;
	w[tot]=ww;
	to[tot]=v;
}
bool bfs(int s){
	queue<int>q;
	q.push(0);
	for(int i=1;i<=n+m+1;i++)
	dis[i]=-1;
	dis[0]=0;
	while(!q.empty()){
		int now=q.front();
		q.pop();
		for(int i=cut[now];i;i=net[i]){
			if(dis[to[i]]!=-1||w[i]==0)continue;
			dis[to[i]]=dis[now]+1;
			q.push(to[i]);
		}
	}
	return dis[t]!=-1;
}
int dfs(int x,int flow){
	cout<<x<<endl;
	if(x==t)
	return flow;
	int last=flow;
	for(int &i=head[x];i;i=net[i]){
		if(dis[to[i]]!=dis[x]+1||w[i]==0)
		continue;
		int nowflow=dfs(to[i],min(last,w[i]));
		last-=nowflow;
		w[i]-=nowflow;
		w[i^1]+=nowflow;
		if(last==0)
		break;
	}
	if(last==flow)
	dis[x]=-1;
	return flow-last;
}
int main(){
	cin>>n>>m>>e;
	t=n+m+1;
	for(int i=1;i<=e;i++){
		int u,v;
		cin>>u>>v;
		add(u,n+v,1);
		add(v+n,u,0);
	}
	for(int i=1;i<=n;i++){
		add(s,i,1);
		add(i,s,0);
	}
	for(int i=1;i<=m;i++){
		add(i+n,t,1);
		add(t,i+n,0);
	}
	while(bfs(s)){
		for(int i=0;i<=n+m+1;i++){
			head[i]=cut[i];
		}
		s+=dfs(s,100000000);
	}
	cout<<s;
	return 0;
}
            ```
2022/12/4 18:59
加载中...