建议加强数据
查看原帖
建议加强数据
611878
sunqihuan楼主2024/11/13 21:48

犯了两个大错误,竟然70分。

正确代码:

#include<bits/stdc++.h>
using namespace std;
int n,m,e,cnt,vis[1005],mat[1005];
vector<int> g[1005];
inline bool dfs(int u){
	for(int i=0;i<g[u].size();i++){
		int v=g[u][i];
		if(!vis[v]){
			vis[v]=1;
			if(!mat[v] || dfs(mat[v])){
				mat[v]=u;
				return 1;
			}
		}
	}
	return 0;
}
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>m>>e;
	for(int i=1;i<=e;i++){
		int u,v;
		cin>>u>>v;
		g[u].push_back(v);
	}
	for(int i=1;i<=n;i++){
		memset(vis,0,sizeof(vis));
		if(dfs(i))cnt++;
	}
	cout<<cnt<<endl;
	return 0;
}


错误代码(70tps):

#include<bits/stdc++.h>
using namespace std;
int n,m,e,cnt,vis[1005],mat[1005];
vector<int> g[1005];
inline bool dfs(int u){
	for(int i=0;i<g[u].size();i++){
		int v=g[u][i];
		if(!vis[v]){
			vis[v]=1;
			if(!mat[v] || dfs(mat[v])){
				mat[v]=v/*不小心写成v,应该是u*/;
				return 1;
			}
		}
	}
	return 0;
}
int main(){
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>m>>e;
	for(int i=1;i<=e;i++){
		int u,v;
		cin>>u>>v;
		g[u].push_back(v);
	}
	for(int i=1;i<=n;i++){
//		memset(vis,0,sizeof(vis));
      //没有上面这一行,忘记清空
		if(dfs(i))cnt++;
	}
	cout<<cnt<<endl;
	return 0;
}


而且样例还全部通过了。

2024/11/13 21:48
加载中...