Dijkstra算法 最短路径 (部分)
2016-02-05 11:35
399 查看
void Dijkstra(int n, int v, int *dist, int *prev, int c[maxnum][maxnum])
{
bool s[maxnum]; // 判断是否已存入该点到S集合中
for(int i=1; i<=n; ++i)
{
dist[i]=c[v][i]; //dist[i]为节点路劲长度,c[v][i]为点与点之间的路径长度。
s[i]=0;
// 初始都未用过该点,s[i]为标志数组。
if(dist[i]==maxint)
prev[i]=0;
else
prev[i]=v;
}
dist[v] = 0;
s[v] = 1;
//依次将未放入S集合的结点中,取dist[]最小值的结点,放入结合S中
//一旦S包含了所有V中顶点,dist就记录了从源点到所有其他顶点之间的最短路径长度
for(int i=2; i<=n; ++i)
{
int tmp = maxint;
int u = v;
// 找出当前未使用的点j的dist[j]最小值
for(int j=1; j<=n; ++j)
if((!s[j]) && dist[j]<tmp)
{
u = j; // u保存当前邻接点中距离最小的点的号码
tmp = dist[j];
}
s[u] = 1; // 表示u点已存入S集合中
// 更新dist
for(int j=1; j<=n; ++j)
if((!s[j]) && c[u][j]<maxint)
{
int newdist = dist[u] + c[u][j];
if(newdist < dist[j])
{
dist[j] = newdist;
prev[j] = u;
}
}
}
}
{
bool s[maxnum]; // 判断是否已存入该点到S集合中
for(int i=1; i<=n; ++i)
{
dist[i]=c[v][i]; //dist[i]为节点路劲长度,c[v][i]为点与点之间的路径长度。
s[i]=0;
// 初始都未用过该点,s[i]为标志数组。
if(dist[i]==maxint)
prev[i]=0;
else
prev[i]=v;
}
dist[v] = 0;
s[v] = 1;
//依次将未放入S集合的结点中,取dist[]最小值的结点,放入结合S中
//一旦S包含了所有V中顶点,dist就记录了从源点到所有其他顶点之间的最短路径长度
for(int i=2; i<=n; ++i)
{
int tmp = maxint;
int u = v;
// 找出当前未使用的点j的dist[j]最小值
for(int j=1; j<=n; ++j)
if((!s[j]) && dist[j]<tmp)
{
u = j; // u保存当前邻接点中距离最小的点的号码
tmp = dist[j];
}
s[u] = 1; // 表示u点已存入S集合中
// 更新dist
for(int j=1; j<=n; ++j)
if((!s[j]) && c[u][j]<maxint)
{
int newdist = dist[u] + c[u][j];
if(newdist < dist[j])
{
dist[j] = newdist;
prev[j] = u;
}
}
}
}
相关文章推荐
- hive实战演练:手机流量统计
- 设置Eclipse console显示全部日志
- 学习博客
- use strict(javascript严格模式)
- 工厂模式
- 依赖倒置原则
- jsp与servlet之间的参数传递【转】
- 点阵字库-学习笔记
- 继承的好处
- 解释器模式——化繁为简
- Spring - Websocket详细配置
- 又封装了一个lookup控件,留作参考吧
- Dynamic Programming for Brother Du
- Growth发布iOS版 — 距今为止最好的开源“Web开发学习”应用
- hihoCoder - 1093 - 最短路径·三:SPFA算法
- wiki/Cg Programming/Unity_shder/Shading in World Space
- noip2002-麦森数 2008.11.4
- libevent入门
- [BZOJ 2301] HAOI 2011 Problem b · 莫比乌斯
- Android实现沉浸式通知栏通知栏背景颜色跟随app导航栏背景颜色而改变