📄 1301 jungle roads.cpp
字号:
//最小生成树
#include <iostream>
using namespace std;
const int Max=0x7fffffff;
int map[30][30],n;
int value[30];
int mintree_prim()
{
int i,j,k,len=0,minp,mind;
for(i=0;i<30;i++)
if(map[0][i]!=0)
value[i]=map[0][i];
else
value[i]=Max;
for(i=0;i<30;i++)
map[i][0]=0;
for(i=1;i<n;i++)
{
mind=Max;
for(j=0;j<30;j++)
if(value[j]<mind)
{
mind=value[j];
minp=j;
}
value[minp]=Max;
len+=mind;
for(j=0;j<30;j++)
map[j][minp]=0;
for(j=0;j<30;j++)
if(map[minp][j]!=0 && map[minp][j] < value[j] )
value[j]=map[minp][j];
}
return len;
}
int main()
{
int t,c,i;
char s,e;
while( cin>>n && n)
{
for(i=0;i<n-1;i++)
{
cin>>s>>t;
while(t--)
{
cin>>e>>c;
map[s-'A'][e-'A']=c;
map[e-'A'][s-'A']=c;
}
}
cout<< mintree_prim() <<endl;
}
return 0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -