代码随想录 打卡第五十八天

卡码网 47 参加科学大会 Dijkstra算法(堆优化)

cpp 复制代码
#include<iostream>
#include<vector>
#include <list>
#include <climits>
#include <queue>
using namespace std;
struct Edge{
    int to;
    int val;

    Edge(int t, int w): to(t), val(w) {} ;
};

struct comparion{
    bool operator ()(const pair<int, int>& a,const pair<int, int>& b) {
        return a.second > b.second;
    }
};

int main(){
    int n,m;
    cin >> n >> m;
    vector<list<Edge>> graph(n+1);
    int x,y,w;
    for(int i = 0;i < m;i++){
        cin >> x >> y >> w;
        graph[x].push_back(Edge(y,w));
    }
    
    vector<bool> visit(n+1,false);
    vector<int> mindistance(n+1,INT_MAX);
    mindistance[1] = 0;
    priority_queue<pair<int, int>,vector<pair<int, int>>,comparion> que;
    
    que.push(pair<int, int>(1,0));
    while(!que.empty()){
        pair<int, int> cur =  que.top();
        que.pop();
        
        visit[cur.first] = true;
        for(Edge edge : graph[cur.first]){
            if(!visit[edge.to] && mindistance[cur.first] + edge.val < mindistance[edge.to]){
                mindistance[edge.to] = mindistance[cur.first] + edge.val;
                que.push(pair<int,int>(edge.to,mindistance[edge.to]));
            }
        }
    }

    int result = mindistance[n] == INT_MAX ? -1 : mindistance[n];
    cout << result;
    return 0;
}

卡码网 94 城市间货物运输 I Bellman-ford算法

cpp 复制代码
#include<iostream>
#include<vector>
#include <climits>
using namespace std;

int main(){
    int n,m;
    cin >> n >> m;
    vector<vector<int>> graph;
    int x,y,w;
    for(int i = 0;i < m;i++){
        cin >> x >> y >> w;
        graph.push_back({x,y,w});
    }

    vector<int> mindistance(n+1,INT_MAX);
    mindistance[1] = 0;
    for(int i = 0;i < n;i++){
        for(vector<int>& side : graph){
            int from = side[0];
            int to = side[1];
            int val = side[2];
            if(mindistance[from] != INT_MAX && mindistance[from] + val < mindistance[to]){
                mindistance[to] = mindistance[from] + val;
            }
        }
    }
    if(mindistance[n] == INT_MAX) cout << "unconnected" << endl;
    else cout << mindistance[n] << endl;

    return 0;
}
相关推荐
pen-ai1 小时前
【HistGBM 系列①】从决策树到梯度提升 —— GBDT 原理精讲
算法·决策树·机器学习
少司府1 小时前
C++基础入门:_stack_queue 底层奥秘
开发语言·数据结构·c++·栈和队列·queue·stack
Cheng小攸1 小时前
协议分析与分析工具(二)
开发语言·php
z_鑫1 小时前
深入理解MyBatis:collection集合封装的底层原理与实现细节
java·开发语言·数据库·spring boot·mybatis
Black蜡笔小新1 小时前
零代码私有化自动化AI算法训练服务器DLTM如何破解企业AI落地难题
人工智能·算法·自动化
贺国亚1 小时前
06-奢侈零售VIP-Clienteling-Agent
开发语言·python·零售
我命由我123451 小时前
Android 开发问题:获取到的 Android ID 发生了变化
android·java·开发语言·java-ee·android studio·android jetpack·android runtime
nix.gnehc1 小时前
Python 内存管理深度解析
开发语言·python
liulilittle1 小时前
回归物理本质:对拥塞控制实验室依赖与公平性误置的反思
网络·tcp/ip·计算机网络·算法·tcp·通信·拥塞控制