运筹说 第80期 | 最小费用最大流问题

news2024/12/22 19:04:09

前面我们学习了图与网络分析的基础知识及经典问题,大家是否已经学会了呢?接下来小编和大家学习最后一个经典问题——最小费用最大流问题

最小费用最大流问题是经济学和管理学中的一类典型问题。在一个网络中每段路径都有“容量”和“费用”两个限制的条件下,此类问题的研究试图寻找出:流量从A到B,如何选择路径、分配经过路径的流量,可以达到所用的费用最小的要求。

如n辆卡车要运送物品,从A地到B地。由于每条路段都有不同的路费要缴纳,每条路能容纳的车的数量有限制,最小费用最大流问题指如何分配卡车的出发路径可以达到费用最低,物品又能全部送到。

下面,让我们从实际问题出发,学习如何解决最小费用最大流问题吧!

一、问题描述及求解原理

01 问题描述

网络G=(V,E,C),每一弧(vi,vj)∈E,给出(vi,vj)上单位流的费用d(vi,vj)≥0(简记dij),记G=(V,E,C,d)。

最小费用最大流问题:

求一个最大流f,使流的总费用取最小值。

02 求解原理

设对可行流f存在增广链𝜇,当沿𝜇以θ=1调整f,得新的可行流f'时,显然V(f')=V(f)+1,两流的费用之差d(f)-d(fx27;):

称为增广链𝜇的费用。

原理依据:

若f是流值为V(f)的所有可行流中费用最小者,而𝜇是关于f的所有增广链中费用最小的增广链,则沿𝜇以θ去调整f,得可行流f',f'就是流量为V(f)+θ的所有可行流中费用最小的可行流。这样,当f'是最大流时,f'就是所求的最小费用最大流。

如果已知f是流量为V(f)的最小费用流→求出关于f的最小费用增广链。

在构造最小费用增广链时,会将网络中的每一条条弧(vi,vj)都变成一对方向相反的弧,以形成四通八达的“路”,因此对于有向边(vi,vj)权wij按如下方法取值:

取值说明如下图所示:

构造赋权有向图W(f),它的顶点是G的顶点,W(f)中弧及其权wij按弧(vi,vj)在G中的情形分为:

新网络W(f)成为流f的(费用)长度网络。

由增广链费用的概念及网络W(f)的定义,知在网络G中寻求关于可行流f的最小费用增广链,等价于在网络W(f)中寻求从vs到vt的最短路。

03 算法步骤

(1)根据网络中的费用首先确定费用最小的长度网络,将该长度网络确定为初始可行流f0=0,令k=0;

(2)应用流量网络对增广链进行调整,记经k次调整得到的最小费用流为fk,构造增量网络W(fk);

(3)在W(fk)中,寻找vs到vt的最短路。若不存在最短路(即最短路路长是∞),则fk就是最小费用最大流;若存在最短路,则此最短路即为原网络G中相应的可增广链𝜇,转入第4步。

(4)在增广链𝜇上fk按下式进行调整,调整量θ为:

得新的可行流fk+1,返回第2步

二、实例应用

01 例题求解

例1:求下图所示网络的最小费用最大流。弧旁数字为(dij,cij)。

解:

(1)取初始可行流f^{0}=0

(2)按算法要求构造长度网络 (f^{0})=0

(3)在原网络G中,与这条最短路对应的增广链为\mu=(\nu_{s},\nu_{2},\nu_{1},\nu_{t})

(4)在原网络D中,与这条最短路对应的增广链为 \mu=(\nu_{s},\nu_{2},\nu_{1},\nu_{t})

按照上述算法依次得 f^{1},f^{2},f^{3},f^{4} ,流量依次为 v(f^{1})=5,v(f^{2})=7,v(f^{3})=10,v(f^{4})=11,构造相应的增量网络为 W(f^{1}),W(f^{2}),W(f^{3}),W(f^{4}),如图(a),(e),(g),(i)所示。

图(i)中,不存在从 v_{s}v_{t}的最短路,所以 f^{4} 为最小费用最大流。

02 拓展延伸

最小费用最大流问题还可以使用线性规划方法进行求解,思路如下:

(1)通过运筹说第78期相关介绍可以求出最大流量

(2)在保证总流量等于最大流量的条件下,以最小化总费用为目标求出每条弧上的流量。

例2:某公司有一个管道网络如下图所示,使用这个网络可以将石油从产地v1送到销地v7,给出了每一段管道的容量cij(单位为:万加仑/小时),此外还给出了每段弧上的单位流量的费用dij(单位为:百元/万加仑),(cij,dij)在图的弧上已标出,如果使用这个网络从产地v1向销地v7运送石油,问怎样运送才能运送最多的石油且使总运费最小?

通过标号算法可以求出最大流量为10。然后,在保证总流量等于10的条件下,以最小化总费用为目标求出每条弧上的流量,如下所示:

后续步骤使用线性规划求解方法如单纯形法求解即可。

以上就是最小费用最大流问题的全部内容了,通过本节学习大家是否对该问题有了一个初步的认识呢,是否可以求解最小费用最大流问题呢?下一次小编将带大家学习第九章——网络计划,敬请关注!

作者 | 张宇 齐鹏

责编 | 刘文志

审核 | 徐小峰

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

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

相关文章

微软Office 2021 批量许可版

软件介绍 微软办公软件套件Microsoft Office LTSC 2021 专业增强版2024年1月批量许可版更新推送!Office2021正式版和Windows11系统同时于2021年10月份正式推出,Office LTSC 2021相比 Office2019正式版变化不太,最主要强化了LOGO设计趋势&…

运维必存的20个常见的故障排查、修复大全

你们好,我的网工朋友。 “稳定是偶然,异常才是常态”。这句话用来形容运维的工作再合适不过了 对于运维来说,工作最常遇到的就是不稳定性带来的各种故障,经常围绕发现故障、响应故障、定位故障、恢复故障这四大步骤打转。 为此…

mysql高级使用教程

mysql体系结构 1.连接层:主要就是做客户端的连接。 2.服务层:主要就是 缓存,分析器,优化器,执行器。 3.引擎层:就是一些存储引擎,包括索引的存储结构。 4.存储层:数据存储的磁盘…

CSS实现超出部分的省略

1、为什么要省略 在日常开发过程中我们难免会遇到后端返回给我们的的数据太长的情况,此时我们通常采取的是...的省略方式,其中的CSS大致如下,既可以实现对应的省略显示,但有些时候我们有需要用户可以查看具体的完整信息&#xff0…

内网yum仓库 ftp;http方式

ftp方式 服务端 客户端 vim /etc/yum.repos.d/ftp.repo http方式 服务端 yum install httpd -y systemctl start httpd cd /var/www/html/ mkdir centos7 mount /dev/sr0 /var/www/html/centos7 客户端

*(长期更新)软考网络工程师学习笔记——Section 22 无线局域网

目录 一、IEEE 802.11的定义二、IEEE 802.11系列标准三、IEEE 802.11的两种工作模式四、CDMA/CA协议(一)CDMA/CA协议的定义(二)CDMA/CA协议的过程 五、AC与AP(一)接入控制器AC(二)无…

go的安装及配置

go的官方下载地址:All releases - The Go Programming Language​​​​​​ 1、找到对应的版本包下载,例如 wget https://golang.google.cn/dl/go1.21.6.linux-amd64.tar.gz 2、下载完成后配置解压Go源码包 tar -zxf go1.21.6.linux-amd64.tar.gz 3…

32 二叉树的定义

之前的通用树结构 采用双亲孩子表示法模型 孩子兄弟表示法模型 引出二叉树 二叉树的定义: 满二叉树和完全二叉树 对此图要有印象 满二叉树一定是完全二叉树,但是完全二叉树不一定是满二叉树 小结

博客摘录「 性能优化:__builtin_expect详解」2024年1月15日

性能优化:__builtin_expect详解___builtin_expect对性能的影响-CSDN博客https://blog.csdn.net/chudongfang2015/article/details/75710848 #define LIKELY(x) __builtin_expect(!!(x), 1) __builtin_expect宏定义中为何写成!!(x)? 首先__buildin_expec…

buuctf-Misc 题目解答分解118-120

118.[INSHack2017]sanity 打开压缩包就是一个md 文件 typora 打开 发现flag INSA{Youre_sane_Good_for_you} 119.粽子的来历 解压压缩包 ,得到文件夹如下 用010 editor 打开 我是A.doc 这个有些可以 都改成FF 保存 然后再次打开 docx 文件就发现了屈原的诗 其他b…

雍禾医疗好医生:雍禾植发张华医生立志服务好毛发患者

作为中国领先的专门从事毛发医疗服务的医疗集团,雍禾医疗提供诊疗、植发、养固等一站式毛发医疗服务,旗下拥有由专业植发品牌“雍禾植发”、医疗养固品牌“史云逊”、女性美学植发品牌“雍禾发之初”及医学假发品牌“哈发达”等组成的全产业链品牌矩阵。…

【Spring 篇】SpringMVC的数据响应:编织美妙的返回乐章

在Web开发的舞台上,数据响应就如同一场美妙的音乐演奏,而SpringMVC作为这场音乐的指挥者,如何优雅地将数据传递给前端,引发了无尽的思考和探索。本篇博客将带你走进SpringMVC的数据响应世界,解开其中的奥秘&#xff0c…

class_5:在c++中一个类包含另一个类的对象叫做组合

#include <iostream> using namespace std;class Wheel{ public://成员数据string brand; //品牌int year; //年限//真正的成员函数void printWheelInfo(); //声明成员函数 };void Wheel::printWheelInfo() {cout<<"我的轮胎品牌是&#xff1a;"<…

JDBC PrepareStatement 的使用(附各种场景 demo)

在 Java 中&#xff0c;与关系型数据库进行交互是非常常见的任务之一。JDBC&#xff08;Java Database Connectivity&#xff09;是 Java 平台的一个标准 API&#xff0c;用于连接和操作各种关系型数据库。其中&#xff0c;PreparedStatement 是 JDBC 中的一个重要接口&#xf…

数据库多表查询练习题

二、多表查询 1. 创建 student 和 score 表 CREATE TABLE student ( id INT ( 10 ) NOT NULL UNIQUE PRIMARY KEY , name VARCHAR ( 20 ) NOT NULL , sex VARCHAR ( 4 ) , birth YEAR , department VARCHAR ( 20 ) , address VARCHAR ( 50 ) ); 创建 s…

pytest pytest-cov生成代码覆盖率报告

pytest-cov 是一个用于 pytest 的插件&#xff0c;它可以生成代码覆盖率报告。代码覆盖率是一个度量&#xff0c;表示在测试过程中执行了代码的哪些部分。这是一个非常有用的工具&#xff0c;因为它可以帮助你理解你的测试是否全面&#xff0c;是否有遗漏的代码部分。 pytest-c…

电商物流查询:未来的发展方向

在电商日益繁荣的时代&#xff0c;物流信息查询不仅关乎消费者体验&#xff0c;更影响着电商运营的效率。快速、准确地追踪物流信息至关重要。本文将简述物流信息快速追踪的价值&#xff0c;并重点介绍固乔快递查询助手这一高效查询工具及其批量查询功能。 一、物流信息快速追踪…

RAG常见七大坑

论文题目&#xff1a;《Seven Failure Points When Engineering a Retrieval Augmented Generation System》 论文地址&#xff1a;https://arxiv.org/pdf/2401.05856.pdf 这篇论文主要探讨了构建检索增强生成系统&#xff08;Retrieval Augmented Generation, RAG&#xff09;…

Javaweb之SpringBootWeb案例员工管理分页查询的详细解析

3. 员工管理 完成了部门管理的功能开发之后&#xff0c;我们进入到下一环节员工管理功能的开发。 基于以上原型&#xff0c;我们可以把员工管理功能分为&#xff1a; 分页查询&#xff08;今天完成&#xff09; 带条件的分页查询&#xff08;今天完成&#xff09; 删除员工&…

【Leetcode 2707】字符串中的额外字符 —— 动态规划

2707. 字符串中的额外字符 给你一个下标从0开始的字符串s和一个单词字典dictionary。你需要将s分割成若干个互不重叠的子字符串&#xff0c;每个子字符串都在dictionary中出现过。s中可能会有一些额外的字符不在任何子字符串中。 请你采取最优策略分割s&#xff0c;使剩下的字…