就错了3个点,大佬来挑挑刺儿
查看原帖
就错了3个点,大佬来挑挑刺儿
425051
超级赛亚人楼主2021/8/18 12:12
#include<bits/stdc++.h>
using namespace std;
struct edge{
	int from,to,w;
}a[250001];
inline int read(){
    int x=0,f=1;
    char ch=getchar();
    while(ch<'0'||ch>'9'){
        if(ch=='-')
            f=-1;
        ch=getchar();
    }
    while(ch>='0'&&ch<='9'){
        x=(x<<1)+(x<<3)+(ch^48);
        ch=getchar();
    }
    return x*f;
}
int sum,fa[501];
bool cmp(edge a,edge b)
{
	return a.w<b.w;
}
int getfa(int x)
{
	if(fa[x]==x)
	return x;
	return fa[x]=getfa(fa[x]);
}

int main()
{
	int n,m,cnt=1,cot=0;
	cin>>n>>m;
	for(int i=1;i<=m;i++)
	{
		for(int j=1;j<=m;j++) 
		{
			if(j==i)
			{
				read();
				fa[i]=i;
				continue;
			}
			a[cnt].w=read();
			if(a[cnt].w==0||a[cnt].w>=n)
			continue;
			a[cnt].to=j;
			a[cnt++].from=i;
		}
	}
	cnt--;
	sort(a+1,a+cnt+1,cmp);
	for(int i=1;i<=cnt&&cot<=m-1;i+=2)
	{
		if(getfa(a[i].from)!=getfa(a[i].to))
		{
			cot++;
			sum+=a[i].w;
			fa[fa[a[i].from]]=fa[a[i].to];
		}
	}
	cout<<sum+(m-cot)*n;
	return 0;
}
2021/8/18 12:12
加载中...