#include <iostream>
#include <cstring>
using namespace std;
#define MaxInt 0x3f3f3f3f
#define N 110
int map[N][N],low[N],visited[N];
int n;
int prim()
{
int i,j,pos,min,result=0;
memset(visited,0,sizeof(visited));
//从某点开始,分别标记和记录该点
visited[1]=1;pos=1;
//第一次给low数组赋值
for(i=1;i<=n;i++)
if(i!=pos) low[i]=map[pos][i];
//再运行n-1次
for(i=1;i<n;i++)
{
//找出最小权值并记录位置
min=MaxInt;
for(j=1;j<=n;j++)
if(visited[j]==0&&min>low[j])
{
min=low[j];pos=j;
}
if(min==MaxInt) return -1;
//最小权值累加
result+=min;
//标记该点
visited[pos]=1;
//更新权值
for(j=1;j<=n;j++)
if(visited[j]==0&&low[j]>map[pos][j])
low[j]=map[pos][j];
}
return result;
}
int main()
{
int m,i,j,v,ans;
while(cin>>m>>n&&m)
{
//所有权值初始化为最大
memset(map,MaxInt,sizeof(map));
while(m--)
{
cin>>i>>j>>v;
if(i!=j)map[i][j]=map[i][j]=v;
}
ans = prim();
if(ans==-1)cout<<"?"<<endl;
else cout<<ans<<endl;
}
return 0;
}
/********************************/
#include <iostream>
#include <cstring>
using namespace std;
#define MaxInt 0x3f3f3f3f
#define N 110
int map[N][N],low[N],visited[N];
int n;
int prim()
{
int i,j,pos,min,result=0;
memset(visited,0,sizeof(visited));
//从某点开始,分别标记和记录该点
visited[1]=1;pos=1;
//第一次给low数组赋值
for(i=1;i<=n;i++)
if(i!=pos) low[i]=map[pos][i];
//再运行n-1次
for(i=1;i<n;i++)
{
//找出最小权值并记录位置
min=MaxInt;
for(j=1;j<=n;j++)
if(visited[j]==0&&min>low[j])
{
min=low[j];pos=j;
}
if(min==MaxInt) return -1;
//最小权值累加
result+=min;
//标记该点
visited[pos]=1;
//更新权值
for(j=1;j<=n;j++)
if(visited[j]==0&&low[j]>map[pos][j])
low[j]=map[pos][j];
}
return result;
}
int main()
{
int m,i,j,v,ans;
while(cin>>m>>n&&m)
{
//所有权值初始化为最大
memset(map,MaxInt,sizeof(map));
while(m--)
{
cin>>i>>j>>v;
if(i!=j)map[i][j]=map[i][j]=v;
}
ans = prim();
if(ans==-1)cout<<"?"<<endl;
else cout<<ans<<endl;
}
return 0;
}
/********************************************/
#include <iostream>
#include <cstring>
using namespace std;
#define MaxInt 0x3f3f3f3f
#define N 110
int map[N][N],low[N],visited[N];
int n;
int prim()
{
int i,j,pos,min,result=0;
memset(visited,0,sizeof(visited));
visited[1]=1;pos=1;
for(i=1;i<=n;i++)
if(i!=pos) low[i]=map[pos][i];
for(i=1;i<n;i++)
{
min=MaxInt;
for(j=1;j<=n;j++)
{
if(visited[j]==0&&min>low[j])
{
min=low[j];pos=j;
}
}
if(min!=MaxInt)
result+=min;
visited[pos]=1;
for(j=1;j<=n;j++)
if(visited[j]==0&&low[j]>map[pos][j])
low[j]=map[pos][j];
}
return result;
}
int main()
{
int i,v,j,ans,c,t;
while(scanf("%d",&n)!=EOF&&n)
{
memset(map,MaxInt,sizeof(map));
for(t=1;t<=n*(n-1)/2;t++)
{
scanf("%d%d%d%d",&i,&j,&v,&c);
if(c==0)map[i][j]=map[j][i]=v;
else map[i][j]=map[j][i]=0;
}
ans=prim();
printf("%d\n",ans);
}
return 0;
}
/*******************************/
原文:http://www.cnblogs.com/ws5167/p/3863870.html