tom

最小生成树

2016-11-29  本文已影响293人  郑明明
最小生成树在实际生活中的应用非常广泛,可以在很多地方看到最小生成树应用的实例。例如:在一个偏僻的村庄,村户都散落在村庄四处,现在需要进行供电建设,需要使用一条电缆将每家每户连接起来,由于村户距离都间隔比较远,那么这时候需要考虑到成本问题,就需要用最短的距离去连接,而最小生成树的成本就是最少的
int c[MAXINT][MAXINT]={{32767,6,1,5,32767,32767},{6,32767,5,32767,3,32767},{1,5,32767,5,6,4},{5,32767,5,32767,32767,2},{32767,3,6,32767,32767,6},{32767,32767,4,2,6,32767}};
void Prim(int n)
{
      int lowcost[MAXINT];// 存储最小生成树中的节点到达其他节点的最短距离
      int closest[MAXINT];// 其他节点到达最小生成树中最近的节点(实际上就是前驱节点)
      bool visited[MAXINT];//bool型变量的S数组表示i是否已经包括在S中
      int i,k;
      visited[0] = true;//从第一个结点开始
      for(i = 1; i <= n; i++)//简单初始化
      {
          lowcost[i] = c[0][i];
          closest[i] = 0; //现在所有的点对应的生成树的最近的点是0
          visited[i] = false;
      }
      for(i = 0; i < n; i++)
      {
         int min = 32767;
         int j = 1;
         for(k = 1; k <= n; k++)//寻找lowcost中的最小值
          {
             if((lowcost[k] < min)&&(!visited[k]))
              {
                 min = lowcost[k];
                 j = k;
              }
          }
          visited[j] = true;
          for(k = 1; k <= n; k++)//因为新加入了j点,所以要查找新加入的j点到未在生成树中的点K中的权值是不是可以因此更小
          {
            if((c[j][k] < lowcost[k])&&(!visited[k])) {
                lowcost[k] =c [j][k];
                closest[k] = j;
              }
          }
      }
  }
上一篇下一篇

猜你喜欢

热点阅读