首页 > 编程语言 >bellman_ford算法

bellman_ford算法

时间:2023-11-01 23:14:43浏览次数:43  
标签:idx int 短路 bellman ford read 算法 wt

Bellman–Ford 算法是一种基于松弛(relax)操作的最短路算法,可以求出有负权的图的最短路,并可以对最短路不存在的情况进行判断。

有边数限制的最短路

普通做法

int ne[N], h[N], idx, e[N], wt[N]; // wt[]表示边权

void add(int u, int v, int w) // 链式前向星存图
{
    idx++;
    e[idx] = v;
    wt[idx] = w; // 边权
    ne[idx] = h[u];
    h[u] = idx;
}

int n, m, k;

int b[N];
int d[N];

int bellman_ford(int s)
{

    for (int i = 1; i <= n; i++)
    {
        d[i] = INF;
    }
    d[s] = 0;
    while (k--)
    {
        for (int i = 1; i <= n; i++)
        {
            b[i] = d[i];
        } // 新的一轮优化之前,把d给b
        for (int u = 1; u <= n; u++)
        {
            if (b[u] == INF)
            {
                continue;
            }
            for (int j = h[u]; j; j = ne[j])
            {
                int v = e[j];
                int w = wt[j];
                if (d[v] > b[u] + w)
                {
                    d[v] = b[u] + w;
                }
            }
        }
    }
    return d[n];
}

signed main()
{
    fst;
    n = read(), m = read(), k = read();
    for (int i = 1; i <= m; i++)
    {
        int u, v, w;
        u = read();
        v = read();
        w = read();
        add(u, v, w);
    }
    int res = bellman_ford(1);
    if (res == INF)
    {
        cout << "impossible" << endl;
        return 0;
    }
    cout << res << endl;
    return 0;
}

堆优化

int n, m, s;

struct vnode
{
    int d;  // 点
    int wt; // 距离
};
vector<vnode> g[N];

bool vis[N];
int d[N];

void spfa(int s)
{
    queue<int> q;
    for (int i = 1; i <= n; i++)
    {
        d[i] = INF;
    }
    d[s] = 0;
    q.push(s);
    vis[s] = 1;
    while (!q.empty())
    {
        // 当队列非空
        // 我们应该去松弛
        int u = q.front();
        q.pop();
        vis[u] = 0;
        // 只要无法在松弛,就找到了最短路
        for (auto e : g[u])
        {
            int v = e.d;
            int w = e.wt;
            if (d[v] > d[u] + w)
            {
                d[v] = d[u] + w;
                if (vis[v] == 0)
                {
                    vis[v] = 1;
                    q.push(v);
                }
            }
        }
    }
}
signed main()
{
    fst;

    n = read(), m = read(), s = read();
    for (int i = 1; i <= m; i++)
    {
        int u, v, w;
        u = read();
        v = read();
        w = read();
        g[u].pb({v, w});
    }
    spfa(s);
    for (int i = 1; i <= n; i++)
    {
        cout << d[i] << " ";
    }
    cout << endl;
    return 0;
}

标签:idx,int,短路,bellman,ford,read,算法,wt
From: https://www.cnblogs.com/gongyuchen/p/17804363.html

相关文章

  • 欧几里得算法
    #include<bits/stdc++.h>usingnamespacestd;intgcd(inta,intb){//欧几里得算法 if(b==0) returna; returngcd(b,a%b);}intexgcd(inta,intb,int&x,int&y){//扩展欧几里得 if(b==0){ x=1; y=0; returna; } intd=exgcd(b,a%b,x,y); intt=x;......
  • 【算法笔记】动态规划Dynamic Programming
    参考视频:5SimpleStepsforSolvingDynamicProgrammingProblems引子:最长递增子串(LongestIncreasingSubsequence,LIS)LIS([31825])=len([125])=3LIS([52863695])=len([2369])=4解决问题的三个步骤:可视化例子(visualizeexample)(“visualizee......
  • 查询算法——顺序查找(优化),二分查找(递归)
    顺序查找顺序查找又称为线性查找,是一种最简单的查找方法。适用于线性表的顺序存储结构和链式存储结构,从第一个元素开始逐个与需要查找的元素x进行比较,当比较到元素值相同时,返回元素m的下标,如果比较到最后都没有找到,则返回-1;时间复杂度为O(n)点击查看代码publicstaticvoidm......
  • spfa算法(求最短路和判断是否存在负环)floyd求最短路(11/1)
    #include<iostream>#include<cstring>#include<algorithm>#include<queue>usingnamespacestd;constintN=100010;intn,m;inth[N];intne[N];inte[N],w[N],idx=0;intdist[N];boolst[N];voidadd(inta,intb,intc){ne[idx]=......
  • 欧几里得算法
    算法说明:用较大数除以较小数,再用出现的余数去除除数,如此反复,直到最后余数是0为止网页链接:https://cn.bing.com/search?q=什么是求两个数的最大公约数的欧几里得算法(辗转相除法)&qs=n&form=QBRE&sp=-1&lq=0&pq=什么是求两个数的最大公约数的欧几里得算法(辗转相除法)&sc=3-27&sk=&cvi......
  • 智慧矿山的关键技术之一:皮带撕裂视频分析AI算法
    随着科技的进步,人工智能(AI)在各行各业的应用越来越广泛。智慧矿山作为矿业领域的发展趋势,对提高矿山安全和生产效率具有重要意义。其中,皮带撕裂是矿山生产中常见的故障之一,因此,利用AI算法对皮带撕裂进行实时监测和预警是智慧矿山的关键技术之一。本文将详细介绍皮带撕裂视频分析AI算......
  • Lnton羚通算法算力云平台交通系统调节方案
    随着汽车保有量的不断增加,城市交通网络面临越来越大的压力。在现代社会中,仅仅依靠道路交通基础建设已经无法满足城市通行需求的提升,必须通过优化城市交通组织,大力发展公共交通系统,并结合智能交通控制系统建设等多种手段与基础建设相辅相成,才能保证城市交通的正常运行,为经济建设提供......
  • Lnton羚通视频分析算法平台构建高清电子警察系统解决方案
    Lnton羚通的算法算力云平台是一款优秀的解决方案,具有突出的特点。它提供高性能、高可靠性、高可扩展性和低成本的特性,使用户能够高效地执行复杂计算任务。此外,平台还提供丰富的算法库和工具,并支持用户上传和部署自定义算法,提升了平台的灵活性和个性化能力。城市交通是城市建设的重......
  • AI视频监控汇聚平台EasyCVR增加算法功能小tips
    安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等,能对外分发RTMP、RTSP、HTTP-FLV、WebSocket-FLV、HLS、WebRTC......
  • Lnton羚通算法算力云平台贵重物品识别系统
    一种基于视觉分析技术的贵重物品识别应用场景是,利用现场摄像头对某一区域内是否存在贵重物品进行实时监测,并通过人工智能视觉分析技术快速发现并识别贵重物品遗失情况,即刻预警,发动安保应急方案,及时止损。该技术可以广泛应用于博物馆、美术馆、珠宝展销会等需要高度防范贵重物品盗窃......