• 板块灌水区
  • 楼主emo_zkt
  • 当前回复0
  • 已保存回复0
  • 发布时间2024/10/18 17:17
  • 上次更新2024/10/18 20:13:00
查看原帖
482163
emo_zkt楼主2024/10/18 17:17

P2504,只有40分

#include<bits/stdc++.h> 
using namespace std;
const int N=2005;
int tot,fa[N],ans,cnt,n,m,ma,u[N],v[N],a[N];
struct nod{
	int x,y,z;
}e[N*N];
bool cmp(nod u,nod v){
	return u.z<v.z;
}
int f(int x){
	if(fa[x]==x)return x;
	return fa[x]=f(fa[x]);
}
void kru(){
	for(int i=1;i<=tot;i++){
		int u=e[i].x,v=e[i].y;
		int xx=f(u),yy=f(v);
		if(xx==yy)continue;
		fa[xx]=yy,cnt++,ma=max(ma,e[i].z);
		if(cnt==n-1)return;
	}
}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		a[i]*=a[i];
	}
	cin>>m;
	for(int i=1;i<=m;i++)fa[i]=i;
	for(int i=1;i<=m;i++){
		cin>>u[i]>>v[i];
		for(int j=1;j<i;j++){
			int d=(u[i]-u[j])*(u[i]-u[j])+(v[i]-v[j])*(v[i]-v[j]);
			e[++tot].x=i,e[tot].y=j,e[tot].z=d;
		}
	}
	sort(e+1,e+tot+1,cmp);
	kru();
	for(int i=1;i<=n;i++){
		if(a[i]>=ma)ans++;
	}
	cout<<ans;
	return 0;
}
2024/10/18 17:17
加载中...