B - 还是畅通工程

#include <stdio.h>
int main()
{
    int e[107][107],dis[107],book[107],i,j,u,n,m,min,k,t1,t2,t3,count=0,sum=0;
    int inf=99999999;
    while(scanf("%d",&n)&&n!=0)
    {
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++)
            if(i==j) e[i][j]=0;
        else e[i][j]=inf;
        for(i=1;i<=(n*(n-1))/2;i++)
        {
            scanf("%d %d %d",&t1,&t2,&t3);
            if(t3==0)
            e[t1][t2]=e[t2][t1]=0;
            else
            e[t1][t2]=e[t2][t1]=t3;
        }
        count=0;
        sum=0;
        for(i=1;i<=n;i++)
        {
            dis[i]=e[1][i];
            book[i]=0;
        }
        book[1]=1;
        count++;
        while(count<n)
        {
            min=inf;
            for(j=1;j<=n;j++)
            {
                if(book[j]==0&&dis[j]<min)
                {
                    min=dis[j];
                    u=j;
                }
            }
            book[u]=1;
            count++;
            sum+=dis[u];
            for(j=1;j<=n;j++)
            {
                if(!book[j]&&dis[j]>e[u][j])
                    dis[j]=e[u][j];
            }
        }
        printf("%d\n",sum);
 
 
    }
    return 0;
 
}


Crawling in process... Crawling failed Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u 

Submit Status 

Description

某省调查乡村交通状况,得到的统计表中列出了任意两村庄间的距离。省政府畅通工程的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可),并要求铺设的公路总长度为最小。请计算最小的公路总长度。 

  

Input

测试输入包含若干测试用例。每个测试用例的第1行给出村庄数目N ( < 100 );随后的N(N-1)/2行对应村庄间的距离,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间的距离。为简单起见,村庄从1N编号。 
N0时,输入结束,该用例不被处理。 

  

Output

对每个测试用例,在1行里输出最小的公路总长度。 

  

Sample Input

 3

1 2 1

1 3 2

2 3 4

4

1 2 1

1 3 4

1 4 1

2 3 3

2 4 2

3 4 5

  

Sample Output

 35 

思路 prim  注意初始化

代码

#include <stdio.h>

int main()

{

    int e[107][107],dis[107],book[107],i,j,u,n,m,min,k,t1,t2,t3,count=0,sum=0;

    int inf=99999999;

    while(scanf("%d",&n)&&n!=0)

    {

        for(i=1;i<=n;i++)

            for(j=1;j<=n;j++)

            if(i==j) e[i][j]=0;

        else e[i][j]=inf;

        for(i=1;i<=(n*(n-1))/2;i++)

        {

            scanf("%d %d %d",&t1,&t2,&t3);

            if(t3==0)

            e[t1][t2]=e[t2][t1]=0;

            else

            e[t1][t2]=e[t2][t1]=t3;

        }

        count=0;

        sum=0;

        for(i=1;i<=n;i++)

        {

            dis[i]=e[1][i];

            book[i]=0;

        }

        book[1]=1;

        count++;

        while(count<n)

        {

            min=inf;

            for(j=1;j<=n;j++)

            {

                if(book[j]==0&&dis[j]<min)

                {

                    min=dis[j];

                    u=j;

                }

            }

            book[u]=1;

            count++;

            sum+=dis[u];

            for(j=1;j<=n;j++)

            {

                if(!book[j]&&dis[j]>e[u][j])

                    dis[j]=e[u][j];

            }

        }

        printf("%d\n",sum);

 

 

    }

    return 0;

 

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值