Dijkstra算法

C实现

#include <stdio.h>
#include <stdlib.h>
#define max 11000000000
int a[1000][1000];
int d[1000]; //d表示某特定边距离
int p[1000]; //p表示永久边距离
int i, j, k;
int m; //m代表边数
int n; //n代表点数
int main()
{
  scanf("%d %d", &n, &m);
  int min1;
  int x, y, z;
  for (i = 1; i <= m; i++)
  {
    scanf("%d%d%d", &x, &y, &z);
    a[x][y] = z;
    a[y][x] = z;
  }
  for (i = 1; i <= n; i++)
    d[i] = max1;
  d[1] = 0;
  for (i = 1; i <= n; i++)
  {
    min1 = max1;
    for (j = 1; j <= n; j++)
      if (!p[j] && d[j] < min1)
      {
        min1 = d[j];
        k = j;
      }
    p[k] = j;
    for (j = 1; j <= n; j++)
      if (a[k][j] != 0 && !p[j] && d[j] > d[k] + a[k][j])
        d[j] = d[k] + a[k][j];
  }
  for (i = 1; i < n; i++)
    printf("%d->", p[i]);
  printf("%d\n", p[n]);
  return0;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容