Chinaunix首页 | 论坛 | 博客
  • 博客访问: 862779
  • 博文数量: 156
  • 博客积分: 6553
  • 博客等级: 准将
  • 技术积分: 3965
  • 用 户 组: 普通用户
  • 注册时间: 2010-06-22 18:36
文章存档

2012年(3)

2011年(43)

2010年(110)

分类: C/C++

2010-10-03 16:34:17

 
#define N 6
#define M 1<<20
int main()
{
 int i, count, startnode, min, path;
 int dist[N], s[N] = {0}, array[N][N] = {{ 0, 20, 15,  M,  M,  M},
                                      { 2,  0,  4,  M, 10, 30},
           { M,  M,  0,  M,  M, 10},
           { M,  M,  M,  0,  M,  M},
           { M,  M,  M, 15,  0, 10},
           { M,  M,  M,  4,  M,  0}};
 startnode = 0;
 s[startnode] = 1;
 count = 1;
 for (i=0; i {
  dist[i] = array[startnode][i];
 }
 while (count < N-1)
 {
  path = M;
  for (i=0; i  {
   if ((s[i] == 0) && (dist[i] < path))
   {
    path = dist[i];
    min = i;
   }
  }
  s[min] = 1;
  for (i=0; i  {
   if ((s[i] == 0) && (dist[i] > dist[min] + array[min][i]))
   {
    dist[i] = dist[min] + array[min][i];
   }
  }
  count++;
 }
 for (i=0; i {
  printf("V%d -> V%d : %d\n", startnode, i, dist[i]);
 }
 return 0;
}
阅读(673) | 评论(0) | 转发(1) |
0

上一篇:图的存储—链表

下一篇:快速排序实现

给主人留下些什么吧!~~