您的位置:首页 > 其它

Dijkstra算法

2015-08-23 22:06 106 查看
http://acm.hdu.edu.cn/showproblem.php?pid=2544

#include <iostream>
#include <string.h>
using namespace std;

const int maxnum = 105;
const int maxint = 999999;

int dist[maxnum];     // 表示当前点到源点的最短路径长度
int cost[maxnum][maxnum];   // 记录图的两点间路径长度
bool vistied[maxnum];

void Dijkstra(int n, int v0)
{
memset(vistied, 0, sizeof(vistied));
for (int i = 1; i <= n; i++)
{
dist[i] = cost[v0][i];
}

vistied[v0] = true;
dist[v0] = 0;
//循环n-1次
for (int i = 2; i <= n; i++)
{
int min = maxint;
int u;
for (int j = 1; j <= n; j++)
{
if (!vistied[j] && min>dist[j])
{
min = dist[j];
u = j;

}
}
vistied[u] = true;
//更新dist
for (int j = 1; j <= n; j++)
{
if (!vistied[j] && min + cost[u][j] < dist[j])
{
dist[j] = min + cost[u][j];
}
}
}
}

int main()
{
//freopen("sample_input.txt", "r", stdin);
// 各数组都从下标1开始

int n, line;             // 图的结点数和路径数
int p, q, len;          // 输入p, q两点及其路径长度

while (1)
{

cin >> n >> line;
// 初始化c[][]为maxint
if (n == 0 && line == 0)
{
break;
}
memset(cost, maxint,sizeof(cost));
for (int i = 1; i <= line; ++i)
{
cin >> p >> q >> len;
if (len < cost[p][q])       // 有重边
{
cost[p][q] = len;      // p指向q
cost[q][p] = len;      // q指向p,这样表示无向图
}
}
Dijkstra(n, 1);
cout <<dist
<< endl;
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: