您的位置:首页 > 其它

单源最短路 Dijkstra O(mlogn) (类实现)

2008-02-18 01:46 260 查看
转载自 Felicia 的bolg
单源最短路 Dijkstra O(mlogn) (类实现)
单源最短路 Dijkstra O(mlogn) (类实现)

#include <iostream>
#include <vector>
#include <map>

#define maxn 1010
using namespace std;
typedef double weight;

class graph_c

void graph_c::init(int _n)

void graph_c::add_edge(int u, int v, weight w)

void graph_c::dijkstra(int S)
weight d, tmp;
int v;
multimap<weight, int>::iterator it;
h.clear();
for (int i = 0; i < n; i++) dist[i] = -1;
dist[S] = 0;
pa[S] = -1;
h.insert(multimap<weight, int>::value_type(0, S));
while (!h.empty())
it = h.begin();
v = it->second;
d = it->first;
h.erase(it);
for (int i = 0; i < r[v].size(); i++)
tmp = d + e[v][i];
int j = r[v][i];
if (dist[j] < 0 || tmp < dist[j])
dist[j] = tmp;
pa[j] = v;
h.insert(multimap<weight, int>::value_type(tmp, j));
}
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: