文章

10

粉丝

76

获赞

78

访问

4.0k

头像
最短路 题解:
P1565 中国科学院大学2021年机试题
发布于2025年2月23日 20:57
阅读数 210

queue实现spfa

#include <bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
const int N = 1005;
struct Edge {
    int b, c;
};
int n, m;
void spfa(int s, int dis[], int vis[], vector<Edge> g[], int pre[]) {
    for (int i = 1; i <= n; i++)
        dis[i] = INF;
    queue<int> q;
    dis[s] = 0;
    vis[s] = 1;
    q.push(s);
    while (!q.empty()) {
        int t = q.front();
        vis[t] = 0;
        q.pop();
        for (int i = 0; i < g[t].size(); i++) {
            Edge e = g[t][i];
            if (dis[t] + e.c < dis[e.b]) {
            &...

登录查看完整内容


登录后发布评论

暂无评论,来抢沙发