运筹学经典问题(二):最短路问题

问题描述

给定一个图(有向图或无向图) G = ( V , E ) G = (V, E) G=(V,E), V V V是图中点的集合, E E E是图中边的集合,图中每条边 ( i , j ) ∈ E (i, j) \in E (i,j)∈E都对应一个权重 c i j c_{ij} cij(距离或者运输成本等),给定一个起点 u u u和一个终点 z z z,最段路问题就是寻找一条从 s s s出发,到达 z z z的距离最短或者成本最低的路径。

数学建模

定义:
I I I:点的集合;
o u t ( i ) out(i) out(i):离开点 i i i边的集合;
i n ( i ) in(i) in(i):进入点 i i i边的集合;
x e x_e xe:是否选择 e e e这条边,0-1变量;
m i n ∑ e ∈ E x e c e s . t . ∑ e ∈ o u t ( i ) x e − ∑ e ∈ i n ( i ) x e = { 1 , i = u − 1 , i = z 0 , e l s e min \sum_{e \in E}x_ec_e \\ s.t. \sum_{e \in out(i)}x_e - \sum_{e \in in(i)}x_e= \begin{cases} 1, i=u \\ -1, i=z \\ 0, else \end{cases} mine∈E∑xeces.t.e∈out(i)∑xe−e∈in(i)∑xe=⎩ ⎨ ⎧1,i=u−1,i=z0,else

上述模型优化目标为最小化路径距离,约束为进出平衡(分了3种点的类型去写约束:始发点只出不进、目的点只进不出、其他点进等于出)。

整数最优解特性

即使把变量 x e x_{e} xe松弛成 0 ≤ x e ≤ 1 0 \leq x_e \leq1 0≤xe≤1,原问题变成线性规划,该问题仍然存在整数最优解。

模型求解

调用求解器求解即可。

  • 后面补充代码。

参考资料

  1. 最短路径问题.
  2. 运筹优化常用算法、模型及案例实战:Python+Java 实现. 刘兴禄,熊望祺,臧永森,段宏达,曾文佳,陈伟坚.
相关推荐
寒秋花开曾相惜3 小时前
(学习笔记)第四章 处理器体系结构
linux·网络·数据结构·笔记·学习
故事和你913 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__3 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__4 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒5 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣5 小时前
力扣热门100题之零钱兑换
算法·leetcode
董董灿是个攻城狮5 小时前
Opus 4.7 来了,我并不建议你升级
算法
LN花开富贵5 小时前
【ROS】鱼香ROS2学习笔记二
linux·笔记·python·学习·嵌入式