nsga2算法c++实现_Bellman-Ford算法

之前文章对于Dijkstra算法进行了讲解和实现,其实现的原理在于采用贪心算法,遍历N(结点数)次,每次找到局部最优的路径的结点u,判断该节点可达的顶点v的权重是否大于结点u权重+u->v的权重,如果大于则替换顶点v的权重(也叫松弛操作)。因为Dijkstra算法无法正确计算负权路径的最短路径(详情可看上一节),所以有了Bellman-Ford算法来解决这一问题。
3363b7bc9b099989a206c7aa6e4aea0c.png

相关文章

图论-图的构建

深度优先搜索遍历图

广度优先搜索遍历图

单源最短路径之Dijkstra算法

贪心算法如何贪心

贝尔曼-福特算法

贝尔曼-福特算法(Bellman-Ford)是由理查德·贝尔曼(Richard Bellman) 和 莱斯特·福特 创立的,求解单源最短路径问题的一种算法。

有时候这种算法也被称为 Moore-Bellman-Ford 算法,因为 Edward F. Moore 也为这个算法的发展做出了贡献。

它的原理是对图进行V-1次松弛操作(V是顶点数量),得到所有可能的最短路径。

其优于Dijkstra算法的方面是边的权值可以为负数、实现简单,缺点是时间复杂度过高,高达O(VE)。但算法可以进行若干种优化,提高了效率。

贝尔曼-福特算法与迪科斯彻算法类似,都以松弛操作为基础,即估计的最短路径值渐渐地被更加准确的值替代,直至得到最优解。

在两个算法中,计算时每个边之间的估计距离值都比真实值大,并且被新找到路径的最小长度替代。

然而,迪科斯彻算法以贪心法选取未被处理的具有最小权值的节点,然后对其出边进行松弛操作;

而贝尔曼-福特算法简单的对所有边进行松弛操作,共V-1次,其中V是图的顶点数量。

在重复地计算中,已计算得到正确的距离的边的数量不断增加,直到所有边都计算得到了正确的路径。

这样的策略使得贝尔曼-福特算法比迪科斯彻算法适用于更多种类的输入

实现过程

从上面介绍我们可以知道,Bellman算法对每一条边采用松弛操作,对于单源最短路径实现来说,

源点到某一顶点所经过的边最多为V-1条(可以看成树的两个结点),如下,三个顶点ABC,A->C最多走过2两条边即A->B->C

A->BA->CB->C

在我们将源点最短路径设置为0时,每次松弛操作,**至少会松弛一条边**,而最多共有N-1条边,所以我们需要遍历N-1次。

每一次遍历的松弛操作和Dijkstra算法类似,判断结点u权重是否大于 v->u的权重+v的权重。

与Dijkstra算法使用最短边向其他顶点扩展方案不同,在Bellman-Ford算法中松弛操作是针对边,其目的是对每一条边进行松弛,

这样总能使得边达到最小,如下图解,A为源点

A->C 2D->C 1A->B -1B->D 1 

上面共计 4个顶点,源点A到达任意顶点B,C,D最高走V-1=3条边,也就是松弛3轮,

初始化时源点A到任意顶点设置为无穷大,s[]表示最短距离,S[A]=0。

那么第一轮:

A -> C 边权2 可以推导==> (S[C] = ∞) > (S[A] + W[AB] = 0+2)条件符合,所以进行松弛操作 S[C] = 2

D -> C 边权1 可以推导==> (S[C] = 2) > (S[D] + W[DC] = ∞+1)条件不符合,无法进行松弛操作

A -> B 边权-1 可以推导==> (S[B] = ∞) > (S[A] + W[AB] = 0+(-1))条件符合,所以进行松弛操作 S[B] = -1

B -> D 边权1 可以推导==> (S[D] = ∞) > (S[B] + W[BD] = -1+1)条件符合,所以进行松弛操作 S[D] = 0

然后进行第二轮(基于第一轮):

A -> C 边权2 可以推导==> (S[C] = 2) > (S[A] + W[AB] = 0+2)条件不符合,无法进行松弛操作

D -> C 边权1 可以推导==> (S[C] = 2) > (S[D] + W[DC] = 0+1)条件符合,所以进行松弛操作 S[C] = 1

A -> B 边权-1 可以推导==> (S[B] = -1) > (S[A] + W[AB] = 0+(-1))条件不符合,无法进行松弛操作

B -> D 边权1 可以推导==> (S[D] = 0) > (S[B] + W[BD] = -1+1)条件不符合,无法进行松弛操作

第三轮逻辑同上。

我们会发现其实第二轮的时候,已经实现最短路径了,第三轮属于没有用的遍历。

负环

负环,又叫负权回路,负权环,指的是一个图中存在一个环,里面包含的边的边权总和<0。在存在负环的图中,是求不出最短路径的,

因为每次要在这个环上遍历,最短路径就会无限次的变小。如下

A->B 1A->C 1C->B -1B->D 1D->C 1

那么BCD就会存在负环,按照上面N-1次遍历后,我们再遍历,最短路径仍会变小。

实现代码(C++)

  main.cpp//  Bellman-Ford  Created by 陈龙.//  Copyright © 2019 陈龙. All rights reserved.//#include using namespace std;//顶点和边和源点int N,E,S; struct Graph{    //起点,终点    int u,v;    int w;//    Graph(int _u,int _v,int _w):u(_u),v(_v),w(_w){};};int main(int argc, const char * argv[]) {    // insert code here...    cin>>N>>E>>S;    Graph g[N];    int dis[N];    int u,v,w;    for (int i=0; i>u>>v>>w;        g[i].u = u;        g[i].v=v;        g[i].w=w;    }    //初始化    dis[S] = 0;    for(int i=0;i g[j].w + dis[g[j].u]) {                dis[g[j].v] =g[j].w + dis[g[j].u];            }        }    }    // 判断是否有负环路    for(int i=0; i dis[g[i].u] + g[i].w){               cout<

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

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

相关文章

JSTL详解(一)

将jstl.jar包导入到工程中 jstldemo1.jsp <% taglib prefix"c" uri"http://java.sun.com/jsp/jstl/core" %> <% page contentType"text/html; charsetgb2312" language"java" %> <c:set var"userName&quo…

android 获取phone实例,Android ContentProvider获取手机联系人实例

在做项目的时候&#xff0c;因为要用到我们自动获取联系人的姓名和电话&#xff0c;就想到了ContentProvider分享数据的功能&#xff0c;这样做既节省了时间&#xff0c;也减少了我们输入错误号码的几率&#xff0c;所以&#xff0c;想在这里把小demo分享给大家&#xff0c;方便…

电脑长截图软件_电脑屏幕长截图+WORD文档里没有插入PDF文件选项时怎么办? 简单一招轻松完成...

111111办 公 小 技 巧在用电脑查看网页时&#xff0c;想把网页上的内容截下来&#xff0c;保存成一张图片&#xff0c;可是内容又不全在一屏里&#xff0c;不能简单的用截屏完成&#xff0c;这时怎么办&#xff1f;想把一个PDF文件插入到WORD文档里&#xff0c;而电脑里的WORD版…

年终总结

时光飞逝,岁月如风,不知不觉新的一年来临了,回顾2010自己收获还是挺多的。虽然钱没余到多少&#xff0c;但是更多的是让我得到了成长、获得了经验。 我是8月份来到了爸妈在线的&#xff0c;很荣幸成为了爸妈在线的一员&#xff0c;同时也很高兴加入了技术研发部这个部门&#x…

Goland配置leetcode

1. 安装 首先在goland的setting界面上找到Plugins&#xff0c;然后搜索关键字leetcode&#xff0c;找到LeetCode Editor&#xff0c;安装它。 在安装后&#xff0c;第一次需要对其进行配置&#xff0c;在Tools中找到LeetCode Plugins&#xff0c;如下图所示进行配置。首先国内…

华为联发科可以升级鸿蒙吗,华为鸿蒙系统降临!首批升级手机确定,联发科芯片被放弃?...

原标题&#xff1a;华为鸿蒙系统降临&#xff01;首批升级手机确定&#xff0c;联发科芯片被放弃&#xff1f;按照计划&#xff0c;华为会在4月份逐渐开放鸿蒙系统手机版的升级&#xff0c;首批可升级的机型目前华为只确定了Mate X2。虽然说这两年采用华为自主芯片的手机&#…

python 多关键字匹配_使用django的objects.filter()方法匹配多个关键字的方法

介绍&#xff1a;今天在使用django的时候忽然想用到&#xff0c;如何匹配多个关键字的操作&#xff0c;我们知道django有一个objects.filter()方法&#xff0c;我们可以通过如下一句代码实现匹配数据库中title包含key关键词的文章名称。table.objects.filter(title__containske…

js中一些怪异的写法

1、var s (10)||{name:janey}   因为10是false,按照或运算规则&#xff0c;继续运算&#xff0c;得到{name:janey} &#xff0c;所以s{name:janey}   同理 var s (11)||{name:janey}&#xff0c;这时11为true,不再继续运算下去&#xff0c;所以strue;   或运算的结果并…

wordpress html页面缓存 cdn,WordPress 下老旧又高效的本地缓存插件 cos-html-cache

摘要Cos Html Cache是一种非常有效的WordPress页面缓存插件可以让你的站点更快更灵敏。基于URL重写&#xff0c;插件将自动生成HTML文件的帖子真正当他们第一次加载&#xff0c;并自动更新HTML文件。说起 WordPress 的缓存插件来对明月来说绝对是个老生常谈的话题了&#xff0c…

python记忆式键入_Python基础

一。基础1.输出与输入&#xff1a;输出&#xff1a;print(变量/字符串)输入&#xff1a;input() 返回的是字符串priceinput()print(price)2.python风格(1)注释 #(2)一般情况是一行结束该句结束&#xff0c;但是如果想要续行&#xff0c;在行的结尾加上 \(3)无需换行符也可以换行…

使用动软代码生成器的注意事项

使用动软代码生成器的注意事项 C# 2011-01-17 21:58:39 阅读21 评论0 字号&#xff1a;大中小 订阅 使用动软代码生成器的注意事项 工厂模式&#xff1a; 一、利用动软生成项目&#xff0c;设置顶级命名空间。二、打开所生成的项目&#xff0c;检查每一层是否为独立的程序集…

html5视差滚动效果,视差滚动效果

插件描述&#xff1a;制作视差滚动效果The meat and potatoes. Invoking these will move that page in from that side.parallax.bar.left(); //Bar slides in from the leftparallax.foo.top(); //bringing back foo from the topparallax.bar.bottom(IAmBack()); //We got c…

Oracle--基础

Oracle数据库的体系结构 数据库: databaseOracle数据库是数据的物理存储,和mysql不一样的是,只要我们愿意,我们就可以在mysql下创建任意的数据库,每个新项目的启动,创建一个数据库,然后通过showdatabases可以查看到全部数据库,但是Oracle的数据库是一个操作系统只有一个库,说白…

python自动化测试常见面试题二_思考|自动化测试面试题第二波

本内容为企业面试关于自动化测试的考题&#xff0c;大家可以自己思考下如何作答&#xff0c;欢迎把答案留言到本文下方哦。问题1&#xff1a;设计接口测试⽤用例例时&#xff0c;涉及的是电商系统&#xff0c;其中包括很多修改&#xff0c;如商品、商家、店铺等等&#xff0c;针…

html动态跟随鼠标效果,使用JS实现气泡跟随鼠标移动的动画效果

气泡跟随鼠标移动&#xff0c;并在每次点击时产生不同的变化效果如下简单的气泡效果body{background-color:#000000;margin:0px;overflow:hidden}var canvas document.createElement(canvas),context canvas.getContext(2d),windowW window.screen.width ,windowH window.s…

raspberry ssh 允许 root 登录

参考链接 csdn 转载于:https://www.cnblogs.com/eat-too-much/p/11153213.html

python开发转行做数据分析_转行学IT,Java、Python、大数据选择学哪个发展好?

对薪资不满意、担心自己以后不好找工作&#xff0c;不少人都会选择参加培训&#xff0c;转行IT行业。当然很多想要转行IT的人&#xff0c;都会犹豫选择哪门编程语言学习比较好&#xff0c;Python、Java、大数据作为比较热门行业技术&#xff0c;不少人都很疑惑转行学Java、Pyth…

html显示线条流动效果,css3实现线条流动效果

1实现原理&#xff1a;通过animation中的clip实现对div的不断切割首先要弄懂clip的含义&#xff0c;四个参数分别是上右下左&#xff0c;以上和左为标准。clip使用的前提是元素绝对定位。本来想实现这样效果看起来是需要3个div&#xff0c;但是根据前人的经验&#xff0c;使用b…

mysql 解析sql文件

简介 如何使用 本地mysql 解析sql文件 方法 参考链接 cnblogs 看三.创建数据库 参考链接 runoob 看选择数据库 参考链接 cnblogs 看往mysql中导入SQL文件 转载于:https://www.cnblogs.com/eat-too-much/p/11153383.html

html的数据类型有哪些,数据库数据类型有哪些

MySQL中定义数据字段的类型对你数据库的优化是非常重要的。MySQL支持多种类型&#xff0c;大致可以分为三类&#xff1a;数值、日期/时间和字符串(字符)类型。推荐教程&#xff1a;MySQL入门视频教程一、数值类型MySQL支持所有标准SQL数值数据类型。这些类型包括严格数值数据类…