dijkstra算法复习

dijkstra算法之前一直没有动手写,经过几次笔试之后,发现对这类问题不是很熟练。今天仔细研究了一下该算法的代码。用一种比较容易理解的方式给code出来。
首先,最直观的表示一个图的方法就是用邻接矩阵,虽然邻接矩阵效率不高,本代码中采用这种方法。
其次,C++中优先队列的使用需要重载<操作符。
最后,并没有对代码进行任何优化,所以十分容易理解。

#include <bits/stdc++.h>
using namespace std;
const int N = 6;
int mat[6][6] = {
        {0, 7, 9, INT_MAX, INT_MAX, INT_MAX},
        {7, 0, 10, 15, INT_MAX, INT_MAX},
        {9, 10, 0, 11, INT_MAX, 2},
        {INT_MAX, 15, 11, 0, 6, INT_MAX},
        {INT_MAX, INT_MAX, INT_MAX, 6, 0, 9},
        {INT_MAX, INT_MAX, 2, INT_MAX, 9, 0},
};
struct node{
    int id, w;
    bool operator < (const node &rhs) const {
        return w < rhs.w;
    }
};
int dis[N];
int main(){
    priority_queue<node> q;
    for(int i = 0; i < N; i++) dis[i] = INT_MAX;
    dis[0] = 0;
    q.push(node({0, 0}));
    while(!q.empty()){
        node x = q.top(); q.pop();
        for(int i = 0; i < N; i++) {
            if(mat[x.id][i] != INT_MAX && dis[i] > x.w + mat[x.id][i]) {
                dis[i] = x.w + mat[x.id][i];
                q.push(node({i, dis[i]}));
            }
        }
    }
    for(int i = 0; i < N; i++) {
        cout << dis[i] << " ";
    }
    return 0;
}

唯一稍微不是十分直观的地方在第29行。代码中并没有在一开始就把除源点之外的所有点都放进优先队列里,而是每次找到最小的扩展点的时候,通过扩展点能缩短距离的那些边给放进优先队列里。

#笔试题目##秋招#
全部评论

相关推荐

2025-12-23 18:51
中南大学 Java
唉又萌混过关:是不是那种收钱盖实习章的机构?
点赞 评论 收藏
分享
01-04 07:53
门头沟学院 C++
心愿便利贴:工作了以后回头再看待这个问题,从客观的视角来讲是因为每个人对自己的要求不同,学习好的人对自己的要求很高,所以觉得考不好就天塌了,认为自己学习好并且值得一份好工作的人也是一样,找不到符合自己预期的工作肯定也会觉得是侮辱,牛客上有很多名校大学生,肯定会存在这种好学生心态啊,“做题区”从来都不是贬义词,这是大部分普通人赖以生存的路径,这个有什么好嘲讽的,有“好学生心态”没有错,但是不要给自己太大的压力了
点赞 评论 收藏
分享
评论
1
8
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务