单源最短路径贪心算法代码cc++
时间: 2023-11-20 07:55:54 浏览: 93
用贪心算法解单源最短路径问题.doc
以下是使用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]; // 表示起点到各点的最短距离
int n, m; // n表示顶点个数,m表示边数
void dijkstra(int s) {
priority_queue<P, vector<P>, greater<P> > que;
memset(d, INF, sizeof(d));
d[s] = 0;
que.push(P(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(P(d[e.to], e.to));
}
}
}
}
int main() {
cin >> n >> m;
for (int i = 0; i < m; i++) {
int a, b, c;
cin >> a >> b >> c;
G[a].push_back(Edge(b, c));
}
dijkstra(1);
for (int i = 1; i <= n; i++) {
cout << d[i] << " ";
}
cout << endl;
return 0;
}
```
阅读全文