热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

关于最小割的进一步理解

以前只知道最小割就是最大流网络流背个模板,没了根本没有深入理解,最近写了一些题才知道自己很$naive$废话不多说,开始正题(假设大家都会网络流的代码,并且知道网络流在做什么

以前只知道最小割就是最大流...网络流背个模板,没了

根本没有深入理解,最近写了一些题才知道自己很 $naive$

废话不多说,开始正题(假设大家都会网络流的代码,并且知道网络流在做什么)

首先最小割就是最大流(废话)

一条图的最小割中,一定有一些边,它们是满流的(如果不满流就不是最大流了)

不妨把这些边称作割边,显然,这些割边把图分成两个部分,一个与源点 $S$ 在同一个部分,一个与汇点 $T$在同一个部分

放图理解:

  首先原图长这样:

  然后一种最小割长这样(红色的是满流的边):

 

我们把与 $S$ 在同一个部分的点集叫作 $S$割,与 $T$ 在同一个部分的点集叫作 $T$割

那么 $S$割 包括点 ${1,2,4}$, $T$割 包括点 ${3,5,6,7}$

注意割边是满流边的子集,比如这个图:

 

割边可以是 $(S,1)$ 或者是 $(1,2)$ ,显然对于这种有多解的最小割随便一种都合法

如果把边看成 $(u,v,cost)$(从 $u$ 到 $v$,花费(流量)是 $cost$ ),考虑最小割的实际意义

就是把点集分成 $S$割 和 $T$割 的最小花费

(请先好好理解以上理论再看下去$qwq$)

 

接下来考虑最小割模型中的三种边:

1. $(S,u,cost)$,意思是 如果 $u$ 在 $T$割(此边满流),那么要产生 $cost$ 的代价

2. $(u,T,cost)$,意思是 如果 $u$ 在 $S$割(此边满流),那么要产生 $cost$ 的代价

再进一步考虑一条边 $(u,v,cost)$ 的实际意义:如果把 $u$ 给 $S$割, $v$ 给 $T$割(此边满流),那么会产生 $cost$ 的代价

扩展一下,对于一条边 $(u,v,cost)$ ,如果 $cost$ 是正无穷 那么这个边的意思是什么?

光速回答,$u$ 和 $v$ 不能在同一个割集!

好像很有道理,因为这个边不可能满流,所以 $u$,$v$ 必须在同一个割集里

但是注意,边是有向边,从 $u$ 到 $v$!如果 $u$ 在 $T$割,$v$ 在 $S$割 也是合法的

所以这条边的真正意思是 ,如果 $u$ 在 $S$割,那么 $v$必须在 $S$割

(休息一下,一定要真正理解边的意义$qwq$)

 

更近一步,对于一种题型:有 $n$ 个点,每个点有一个价值 $val$ (可能为负),点之间有一些限制关系 $(x,y)$(选了点 $x$ 必须选点 $y$),并且保证对于任意限制 $(x,y)$, $val[x]>0,val[y]<0$,求获得的最大价值

显然最大价值相当于总的正的价值减去 最小要失去的价值(有些正点不能选,有些负点要选),考虑求出最小要失去的价值

构建网络流模型,把点 $u$ 给 $S$割 表示选择点 $u$,给 $T$割 说明不选点 $u$

对于一个限制 $(x,y)$,连 $(S,x,val[x])$,此边为割边表示 $x$ 不在 $S$割,那么就相当于不选择 $x$,会失去 $val[x]$ 价值(对最小割产生 $val[x]$ 的贡献)

连 $(y,T,-val[y])$ ,此边为割边表示 $y$ 在 $S$ 割,相当于选择 $y$,会得到 $val[y]$ 的负的价值(对最小割产生 $-val[y]$ 的贡献)

连 $(x,y,INF)$ 表示如果 $x$ 在 $S$割,那么 $y$ 也在 $S$割(选 $x$ 必须选 $y$)

因为最终每个点都要确定选或者不选,所以必须要把点集分成 $S$割 和 $T$割

所以最小割就是最小要失去的价值

 

例题:太空飞行计划问题

 

把实验看成正点,仪器看成负点,然后限制关系就是限制关系,直接把上面的方法套进来就好了$qwq$

要输出具体方案,直接看看那些点在 $S$割就好了,(网络流就不用放代码了吧$qwq$,毕竟网络流考的是建模$qwq$)

 

另一题例题:最大获利(同样的方法,不用再解释了吧$qwq$)

 

用这种思想可以很容易地证明最大权闭合子图的正确性(比我在网上看的其他方法好多了$qwq$)


推荐阅读
  • 本文比较了eBPF和WebAssembly作为云原生VM的特点和应用领域。eBPF作为运行在Linux内核中的轻量级代码执行沙箱,适用于网络或安全相关的任务;而WebAssembly作为图灵完备的语言,在商业应用中具有优势。同时,介绍了WebAssembly在Linux内核中运行的尝试以及基于LLVM的云原生WebAssembly编译器WasmEdge Runtime的案例,展示了WebAssembly作为原生应用程序的潜力。 ... [详细]
  • 阿里Treebased Deep Match(TDM) 学习笔记及技术发展回顾
    本文介绍了阿里Treebased Deep Match(TDM)的学习笔记,同时回顾了工业界技术发展的几代演进。从基于统计的启发式规则方法到基于内积模型的向量检索方法,再到引入复杂深度学习模型的下一代匹配技术。文章详细解释了基于统计的启发式规则方法和基于内积模型的向量检索方法的原理和应用,并介绍了TDM的背景和优势。最后,文章提到了向量距离和基于向量聚类的索引结构对于加速匹配效率的作用。本文对于理解TDM的学习过程和了解匹配技术的发展具有重要意义。 ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • JavaScript设计模式之策略模式(Strategy Pattern)的优势及应用
    本文介绍了JavaScript设计模式之策略模式(Strategy Pattern)的定义和优势,策略模式可以避免代码中的多重判断条件,体现了开放-封闭原则。同时,策略模式的应用可以使系统的算法重复利用,避免复制粘贴。然而,策略模式也会增加策略类的数量,违反最少知识原则,需要了解各种策略类才能更好地应用于业务中。本文还以员工年终奖的计算为例,说明了策略模式的应用场景和实现方式。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文介绍了Linux系统中正则表达式的基础知识,包括正则表达式的简介、字符分类、普通字符和元字符的区别,以及在学习过程中需要注意的事项。同时提醒读者要注意正则表达式与通配符的区别,并给出了使用正则表达式时的一些建议。本文适合初学者了解Linux系统中的正则表达式,并提供了学习的参考资料。 ... [详细]
  • 本文介绍了如何使用python从列表中删除所有的零,并将结果以列表形式输出,同时提供了示例格式。 ... [详细]
author-avatar
hedongsheng
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有