标签:node std int long maxn 50000 hdu1102
将已有边权设为零,再跑kruskal……
#include<bits/stdc++.h> using namespace std; #define int long long const int maxn=50000; struct node{ int x,y,z; }a[maxn]; int n,q,cnt; int fa[maxn]; int cmp(node x,node y){ return x.z<y.z; } int find(int x){ if(fa[x]==x)return x; return fa[x]=find(fa[x]); } signed main(){ while(scanf("%lld",&n)!=EOF){ int x,y; cnt=0; for(int i=1;i<=n;i++) fa[i]=i; for(int i=1;i<=n;i++) for(int j=1;j<=n;j++){ scanf("%lld",&x); a[++cnt]=(node){i,j,x}; } cin>>q; for(int i=1;i<=q;i++){ scanf("%lld%lld",&x,&y); a[(x-1)*n+y].z=0; a[(y-1)*n+x].z=0; //if(find(x)!=find(y)) // fa[find(x)]=find(y); } sort(a+1,a+1+cnt,cmp); int edge=0,tot=0; for(int i=1;i<=cnt;i++){ x=a[i].x,y=a[i].y; if(find(x)!=find(y)){ fa[find(x)]=find(y); tot+=a[i].z; edge++; } if(edge==n-1)break; } printf("%lld\n",tot); } return 0; } /* 3 0 990 692 990 0 179 692 179 0 1 1 2 */
标签:node,std,int,long,maxn,50000,hdu1102 来源: https://www.cnblogs.com/syzf2222/p/12422233.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。