zoukankan      html  css  js  c++  java
  • HDU-1863 畅通工程

    应用了prim算法模板,一下子就过了。 

                             畅通工程

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 13084    Accepted Submission(s): 5358

    Problem Description
    省政府“畅通工程”的目标是使全省任何两个村庄间都可以实现公路交通(但不一定有直接的公路相连,只要能间接通过公路可达即可)。经过调查评估,得到的统计表中列出了有可能建设公路的若干条道路的成本。现请你编写程序,计算出全省畅通需要的最低成本。
     
    Input
    测试输入包含若干测试用例。每个测试用例的第1行给出评估的道路条数 N、村庄数目M ( < 100 );随后的 N
    行对应村庄间道路的成本,每行给出一对正整数,分别是两个村庄的编号,以及此两村庄间道路的成本(也是正整数)。为简单起见,村庄从1到M编号。当N为0时,全部输入结束,相应的结果不要输出。
     
    Output
    对每个测试用例,在1行里输出全省畅通需要的最低成本。若统计数据不足以保证畅通,则输出“?”。
     
    Sample Input
    3 3
    1 2 1
    1 3 2
    2 3 4
    1 3
    2 3 2
    0 100
     
    Sample Output
    3
    ?
     
    Source
     
    Recommend
    lcy
     1 #include<stdio.h>
     2 #define max 10000000
     3 int  map[101][101],visit[101];
     4 int length[101];
     5 int getmin(int n)
     6 {
     7       int i,min;
     8     for(i=1;i<=n;i++)
     9     {
    10         if(visit[i]==0)
    11         {
    12             min=i;
    13             break;
    14         }
    15     }
    16    for(i++;i<=n;i++)
    17    {
    18        if(visit[i]==0&&length[min]>length[i])
    19              min=i;
    20    }
    21       return min;
    22 }
    23 int prim(int n)
    24 {
    25     int i,j;
    26     int min;
    27     int sum;
    28     for(i=1;i<=n;i++)
    29     {
    30         visit[i]=0;
    31         length[i]=map[1][i];
    32     }
    33        visit[1]=1;
    34          sum=0;
    35      for(i=2;i<=n;i++)
    36      {
    37          min=getmin(n);
    38          visit[min]=1;
    39          sum+=length[min];
    40          for(j=1;j<=n;j++)
    41          {
    42              if(visit[j]==0)
    43              {
    44                  if(map[min][j]<length[j])
    45                  {
    46                      length[j]=map[min][j];
    47                  }
    48              }
    49          }
    50      }
    51      return sum;
    52 }
    53 int main()  
    54 {  
    55     int n, m;  
    56     int i,j;  
    57     int min;  
    58     int u, v, cost;  
    59     while (~scanf("%d%d",&m,&n)&&m!=0)  
    60     {  
    61        for(i=1;i<=n;i++)
    62           for(j=1;j<=n;j++)
    63                 map[i][j]=max;
    64         for (i = 0; i <= n; i++)  
    65             map[i][i] = 0;  
    66         for (i = 0;i<m;i++)  
    67         {  
    68             scanf("%d%d%d", &u, &v,&cost);  
    69                 map[u][v] = cost;  
    70                 map[v][u] = cost; 
    71         } 
    72           min = prim(n);
    73         if(min>=max)
    74             printf("?
    ");
    75         else
    76           printf("%d
    ",min);  
    77     }
    78     return 0;
    79 }  

     用了浓缩的prim的模板,出错了,却怎么也找不到什么错误。

    #include<stdio.h>
    #include<string.h>
    #define MAX 100000
    int map[101][101],v[101];
    int prim(int n)//最好的prim的模板。
    {
        int k[510],i,j;
        int min,sum=0,flag,count=1;
        memset(k,0,sizeof(k));
        memset(v,0,sizeof(v));
        for(i=1;i<=n;i++)
            k[i]=map[1][i];
        for(i=2;i<=n;i++)
        {
            min=MAX;
            for(j=2;j<=n;j++)
            {
                if(min>k[j]&&v[j]==0)
                {
                    min=k[j];
                    flag=j;
                }
            }
            sum+=min;
            v[flag]=1;
            for(j=1;j<=n;j++)
                if(v[j]==0&&k[j]>map[flag][j]&&flag!=j)
                    k[j]=map[flag][j];
        }
      return sum;
    }
    int main()
    {
       int n,m,i,j,p,q,r,min;
       while(~scanf("%d%d",&m,&n)&&m!=0)
        {
           for(i=1;i<=n;i++)
                for(j=1;j<=n;j++)
                {
                    if(i==j) map[i][j]=0;
                    else 
                        map[i][j]=MAX;
                }
                for(i=0;i<m;i++)
                {
                    scanf("%d%d%d",&p,&q,&r);
                    map[p][q]=map[q][p]=r;
                }
            min=prim(n);//调用出错了。怎么改?
          if(min>=MAX)
          printf("?
    ");
          else
            printf("%d
    ",min);
        }
        return 0;
    }
  • 相关阅读:
    poj1088 经典dp
    poj2301
    poj1050(nyoj104 zoj1074)dp问题
    hdu1003
    poj1001(高精度)
    图的深度优先遍历DFS
    jquery中attr和prop的区别
    Apache 配置域名入口路径
    关于启动定时器和取消定时器的问题
    Web攻防之XSS,CSRF,SQL注入
  • 原文地址:https://www.cnblogs.com/cancangood/p/3296575.html
Copyright © 2011-2022 走看看