犯了两个大错误,竟然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;
}
而且样例还全部通过了。