Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
54897 | 杨竣周 | 最优布线问题 | C++ | 运行出错 | 0 | 1 MS | 2208 KB | 739 | 2022-07-29 17:46:25 |
#include<bits/stdc++.h> using namespace std; int d[501][501],a[501][501],n,ans; bool st[501]; void input(){ memset(d,0x3f,sizeof(d)); memset(a,0x3f,sizeof(a)); int u,v,w; cin>>n; for(int i=1;i<=n;i++){ cin>>u>>v>>w; d[u][v]=w; d[v][u]=w; } } void prim(){ st[1]=0; for(int i=1;i<=n;i++){ int tt=0x3f3f3e,t; for(int j=1;j<=n;j++){ if(d[i][j]<=tt){ tt=d[i][j],t=j; } if(tt==0x3f3f3e) continue; a[i][t]=d[i][t]; st[t]=1; } } } void output(){ for(int i=1;i<=n;i++){ if(!st[i]){ printf("impossible"); return; } } for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) ans+=a[i][j]; printf("%d",ans/2); } int main(){ input(); prim(); output(); return 0; }