解题:
这次感觉还可以,不再是水水的,还不错哦~
- 注意数组开的够用
- 顶点集:女生(0…N-1 ) 男生(N…N+M-1)
- 求最小生成树f,输出10000*(N+M)-f即可
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int Max_n=2e4+10;
const int Max_m=5e5+10;
struct edge{
int from,to,cost;
bool operator<(const edge& e)const{
return cost>e.cost;
}
}e[Max_m];
int T,N,M,R;
int par[Max_n];
int Find(int x){
if(par[x]==x)return x;
return par[x]=Find(par[x]);
}
int Kruskal(){
for(int i=0;i<N+M;i++)par[i]=i;
int sum=0;
sort(e,e+R);
for(int i=0;i<R;i++){
int x=Find(e[i].from);
int y=Find(e[i].to);
if(x!=y){
sum+=e[i].cost;
par[x]=y;
}
}
return sum;
}
int main()
{
scanf("%d",&T);
while(T--){
scanf("%d%d%d",&N,&M,&R);
int a,b,c;
for(int i=0;i<R;i++){
scanf("%d%d%d",&a,&b,&c);
e[i].from=a;e[i].to=b+N;
e[i].cost=c;
}
printf("%d\n",10000*(N+M)- Kruskal());
}
return 0;
}