求最短路径之BF算法

news2024/9/29 18:48:00

介绍

全称Bellman-Ford算法,目的是求解有负权边的最短路径问题。
考虑环,根据环中边的边权之和的正负,将环分为零环、正环、负环。其中零环、正环不会影响最短路径的求解,而负环会影响最短路径的求解。
可用BF算法返回一个bool值来判断是否有负环,如果有返回false,否则返回true.

bool BF(int b){
    fill(path,path+maxn,INF);
    path[b]=0;
    //求最短距离
    for(int i=0;i<n-1;i++){//比较趟数
        for(int j=0;j<n;j++){//遍历每一个顶点相关的邻接边
            for(int k=0;k<table[j].size();k++){
                int v=table[j][k].v;
                int value=table[j][k].value;
                if(path[j]+value<path[v]){
                    //此时path[v]应该是最小距离
                    path[v]=path[j]+value;
                }
            }
        }
        //判断是否有负环:有返回false,无返回true
        for(int m=0;m<n;m++){//再次遍历边时
            for(int k=0;k<table[m].size();k++){
                int v=table[m][k].v;
                int value=table[m][k].value;
                if(path[m]+value<path[v])
                //还能找到有比path[v]更小的距离
                return false;//说明有负环存在
            }
        }
        return true;//否则无负环
    }
}

设计思想

将求最短路径看作是求以源点为根结点的一棵最短路径树,此时图与起点均确定,因此最短路径树也就确定了,且最短路径树的层数一定不超过顶点个数V,即树中两顶点的比较更新次数不超过V-1轮。

实现

由于用邻接矩阵遍历边时,复杂度会达到O(V的3次方),因此我们使用邻接表去实现

应用

由于求最短路径条数时,BF算法会重复遍历相同的顶点,因此在有多条最短路径数时,最短路径条数的累加会出错。于是我们想到用set容器记录前驱结点,通过遍历去重后的前驱结点进行累加。
set容器的介绍
在这里插入图片描述

#include <iostream>
#include <vector>
#include <set>
#include <algorithm>
using namespace std;
const int maxn=100;
const int INF=1000000000;
struct node{
    int v;//邻接顶点
    int value;//对应边权
    //通过构造函数实现定义同时初始化
    node(int a,int b):v(a),value(b){}
};
vector<node> table[maxn];
int n,edge,st,ed,weight[maxn];

int path[maxn],num[maxn],w[maxn];
set<int> pre[maxn];//记录前驱,以便去重

void BF(int b){
     fill(path,path+maxn,INF);
     memset(num,0,sizeof(num));
     memset(w,0,sizeof(w));
     path[b]=0;
     w[b]=weight[b];
     num[b]=1;
     for(int i=0;i<n-1;i++){
         for(int j=0;j<n;j++){
             for(int k=0;k<table[j].size();k++){
                 //记录
                 int v=table[j][k].v;
                 int value=table[j][k].value;
                 if(path[j]+value<path[v]){
                     path[v]=path[j]+value;
                     w[v]=w[j]+weight[v];
                     num[v]=num[j];//小于覆盖
                     pre[v].clear();//清空
                     pre[v].insert(j);//记录最短路径前驱
                 }else if(path[j]+value==path[v]){
                     if(w[v]<w[j]+weight[v])
                     w[v]=w[j]+weight[v];
                     pre[v].insert(j);//继续记录
                     num[v]=0;//防止重复计数,清空
                     //重新累加计数:通过遍历前驱结点实现
                     for( set<int>::iterator it=pre[v].begin();it!=pre[v].end();it++)
                     num[v]+=num[*it];//*it=pre[j][k],即k的前驱
                 }
             }
         }
     }
 }

int main(){
    int v1,v2,weigh;
    cin>>n>>edge>>st>>ed;
    for(int i=0;i<n;i++)
    cin>>weight[i];
    for(int j=0;j<edge;j++){//构建邻接表
        cin>>v1>>v2>>weigh;
        table[v2].push_back(node(v1,weigh));
        table[v1].push_back(node(v2,weigh));
    }
    BF(st);
    cout<<num[ed]<<" "<<w[ed]<<endl;
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1485216.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java开发环境配置一指禅

IDEA下载与安装 IDEA 全称 IntelliJ IDEA&#xff0c;是java编程语言的集成开发环境。 idea下载地址 。 JDK安装配置 JDK是 Java 语言的软件开发工具包&#xff0c;主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心&#xff0c;它包含了JAVA的运行环…

vue项目获取拼音首字母

工具包 pinyin-pro npm install pinyin-pro 官方地址 pinyin-pro | pinyin-pro性能优异、转换准确的 js 中文转拼音工具https://pinyin-pro.cn/示例代码(获取每个汉字的拼音首字母) import {pinyin} from pinyin-pro;function getPinyinInitial(name){if (name) {let py p…

aop监控spring cloud接口超时,并记录到数据库

引入pom <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0…

PlantUML简介

PlantUML简介 plantUML是一款开源的UML图绘制工具&#xff0c;支持通过文本来生成图形&#xff0c;使用起来非常高效。可以支持时序图、类图、对象图、活动图、思维导图等图形的绘制。你可以在IDEA中安装插件来使用PlantUML, 或者在Visual Studio Code中安装插件。 也可以在dra…

2024免费mac苹果电脑的清理和维护软件CleanMyMac X

对于 Mac 用户来说&#xff0c;电脑的清理和维护是一件让人头疼的事情。但是&#xff0c;有了 CleanMyMac X&#xff0c;这一切都将变得轻松愉快。CleanMyMac X 是一款专为 Mac 设计的电脑清理软件&#xff0c;它以其强大的功能和简单的操作&#xff0c;让无数用户为之倾倒。 C…

C语言学习DAY22

内存泄漏&#xff1a;开辟的内存空间不使用了&#xff0c;但不释放该内存空间。

AutoSAR(基础入门篇)13.3-Mcal Dio配置

目录 一、Dio port配置 二、Dio pin配置 一、Dio port配置 同之前的Port一样,双击进入Dio配置界面后会看到几乎差不多的配置界面。General和Port类似,我们不再赘述,主要讲解Dio的配置 1. 其实Dio并没有什么实质的作用,主要起到了一个重命名的功能。双击DioConfig_0进入下…

spring项目单元测试

单元测试 每个功能开发完&#xff0c;项目上线前都要做单元测试 引入依赖 AssertJ&#xff1a;断言 测试用例 编写测试用例要求&#xff1a;保证测试方法的独立性 当前测试方法不能依赖于别的测试方法&#xff0c;也不依赖于数据库中某条特定数据。 如A方法插入一条数据&a…

在网页上踢球:打造我自己的python(Django)足球网站

足球不仅仅是球场上的90分钟。它是一个不断发展的故事&#xff0c;一个全球球迷社群的粘合剂&#xff0c;一个数据和热情交织的世界。作为一名开发者和球迷&#xff0c;我决定将这两大爱好结合起来&#xff0c;用 Django 打造一个足球网站&#xff0c;让球迷们能够追踪他们最爱…

LeetCode --- 三数之和

题目描述 三数之和 代码解析 暴力 在做这一道题的时候&#xff0c;脑海里先想出来的是暴力方法&#xff0c;一次排序&#xff0c;将这个数组变为有序的&#xff0c;再通过三次for循环来寻找满足条件的数字&#xff0c;然后将符合条件的数组与之前符合条件的数组进行一一对比…

YOLOv9独家原创改进|使用HWD:Haar小波下采样模块

专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;主力高效涨点&#xff01;&#xff01;&#xff01; 一、论文简介 最大池化或跨步卷积等下采样操作在卷积神经网络&#xff08;CNNs&#xff09;中广泛使用&#xff0c;以聚合局部特征&#xff0c;扩大感…

基于springboot+vue的客户关系管理系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

Linux系统管理:虚拟机 Kali Linux 安装

目录 一、理论 1.Kali Linux 二、实验 1.虚拟机Kali Linux安装准备阶段 2.安装Kali Linux 2. Kali Linux 更换国内源 3. Kali Linux 设置固定IP 4. Kali Linux 开启SSH远程连接 5. MobaXterm远程连接 Kali Linux 三、问题 1.apt 命令 取代哪些 apt-get命令 一、理论…

ChatGPT支持下的PyTorch机器学习与深度学习技术应用

近年来&#xff0c;随着AlphaGo、无人驾驶汽车、医学影像智慧辅助诊疗、ImageNet竞赛等热点事件的发生&#xff0c;人工智能迎来了新一轮的发展浪潮。尤其是深度学习技术&#xff0c;在许多行业都取得了颠覆性的成果。另外&#xff0c;近年来&#xff0c;Pytorch深度学习框架受…

探索那些能唤起情感共鸣的壁纸

1、方小童在线工具集 网址&#xff1a; 方小童 该网站是一款在线工具集合的网站&#xff0c;目前包含PDF文件在线转换、随机生成美女图片、精美壁纸、电子书搜索等功能&#xff0c;喜欢的可以赶紧去试试&#xff01;

平台工程: 用Backstage构建开发者门户 - 2

本文介绍了如何使用开源Backstage构建自己的开发者门户&#xff0c;并基于此实践平台工程。本系列共两篇文章&#xff0c;这是第二篇。原文: Platform Engineering: Building Your Developer Portal with Backstage — Part 2 在本教程第一部分中我们了解了Backstage这个用于构…

Docker基础教程 - 1 Docker简介

更好的阅读体验&#xff1a;点这里 &#xff08; www.doubibiji.com &#xff09; 1 Docker简介 Docker是一个强大的容器化平台&#xff0c;让你能够更轻松地构建、部署和运行应用程序。 下面我们来学习 Docker。 1.1 Docker是什么 1 现在遇到的问题 每次部署一台服务器&…

Python学习 day07(JSON)

JSON 各种编程语言存储数据的容器不尽相同&#xff0c;在Python中有字典dict这样的数据类型&#xff0c;而其他语言可能没有对应的字典&#xff0c;为了让不同的语言都能够相互通用的传递数据&#xff0c;JSON就是一种非常良好的中转数据格式&#xff0c;如下&#xff1a; JSON…

广和通5G智能模组SC171支持Android、Linux和Windows系统,拓宽智能物联网应用

世界移动通信大会2024期间&#xff0c;广和通宣布&#xff1a;5G智能模组SC171除支持Android操作系统外&#xff0c;还兼容Linux和Windows系统&#xff0c;帮助更多智能终端客户快速迭代产品&#xff0c;拓宽智能化应用覆盖范围。 广和通SC171系列基于高通QCM6490物联网解决方案…

flstudio21中文版下载百度网盘2024最新版本下载

FL Studio 21有中文版。从FL Studio 20.8版本起&#xff0c;软件就开始支持简体中文。用户可以在软件设置中选择中文作为界面语言&#xff0c;从而更方便地使用各项功能。此外&#xff0c;FL Studio 21的中文版还针对中国用户进行了优化&#xff0c;提供了更加本地化的支持和使…