c++实现dijkstra算法
时间: 2023-12-08 18:37:55 浏览: 100
dijkstra算法 C++实现
4星 · 用户满意度95%
以下是C++实现Dijkstra算法的代码示例:
```c++
#include <iostream>
#include <vector>
#include <queue>
#include <cstring>
using namespace std;
const int INF = 0x3f3f3f3f; // 定义一个无穷大的常量
struct Edge {
int to, cost;
Edge(int to, int cost) : to(to), cost(cost) {}
};
typedef pair<int, int> P; // first是最短距离,second是顶点编号
vector<Edge> G[1000]; // 图的邻接表表示
int d[1000]; // 存储起点到各个顶点的最短距离
void dijkstra(int s) {
priority_queue<P, vector<P>, greater<P>> que; // 小根堆
memset(d, INF, sizeof(d)); // 初始化距离数组
d[s] = 0;
que.push(make_pair(0, s));
while (!que.empty()) {
P p = que.top();
que.pop();
int v = p.second;
if (d[v] < p.first) continue; // 已经求得最短距离
for (int i = 0; i < G[v].size(); i++) {
Edge e = G[v][i];
if (d[e.to] > d[v] + e.cost) {
d[e.to] = d[v] + e.cost;
que.push(make_pair(d[e.to], e.to));
}
}
}
}
int main() {
int n, m, s;
cin >> n >> m >> s; // n是顶点数,m是边数,s是起点
for (int i = 0; i < m; i++) {
int u, v, w;
cin >> u >> v >> w; // u和v是边的两个端点,w是边的权值
G[u].push_back(Edge(v, w));
}
dijkstra(s);
for (int i = 0; i < n; i++) {
cout << d[i] << " ";
}
cout << endl;
return 0;
}
```
阅读全文