力扣刷题之旅:高阶篇(五)—— 网络流算法:最大流与最小割

news2024/11/30 0:31:48

          力扣(LeetCode)是一个在线编程平台,主要用于帮助程序员提升算法和数据结构方面的能力。以下是一些力扣上的入门题目,以及它们的解题代码。  

        

目录

引言

一、最大流与最小割的基本概念

二、力扣上的题目

题目描述:“最大流”(Maximum Flow)

输入格式:

输出格式:

示例:

输入:

输出: 

解释:

以下是使用Edmonds-Karp算法解决最大流问题的Python代码示例:

四、算法分析

五、总结


  

--点击进入刷题地址 


引言

        在算法领域中,网络流算法是一个重要且实用的工具,尤其在处理资源分配、运输优化等问题上表现出色。最大流和最小割是网络流算法中的两个核心概念,它们在很多实际应用中都有着广泛的使用。

一、最大流与最小割的基本概念

        在一个有向图中,如果存在一个源点s和一个汇点t,以及每条边上都有一个非负容量限制,那么这样的图就被称为一个流网络。最大流问题是在这样的流网络中寻找从源点s到汇点t可以传输的最大流量。而最小割问题则是寻找一个割集,使得割集中所有边的容量之和最小,同时确保源点s汇点t在不同的子图中。

二、力扣上的题目

题目描述:最大流Maximum Flow

        给定一个有向图,其中每个节点表示一个地点,每条边表示两个地点之间的连接,边上的权重表示该连接的容量。请找出从源点s到汇点t的最大流量。

输入格式
  • 第一行包含四个整数n、m、s、t,分别表示节点的数量、边的数量、源点和汇点。
  • 接下来m行,每行包含三个整数u、v、c,表示从节点u到节点v有一条容量为c的边。
输出格式
  • 输出一个整数,表示从源点s到汇点t的最大流量。
示例
输入
4 4 1 4  
1 2 1  
2 3 2  
3 4 2  
1 4 1
输出: 
2
解释

        上述输入表示一个有向图,其中节点1是源点,节点4是汇点。从节点1到节点4的最大流量为2,可以通过两条路径实现:1→2→3→4和1→4。

三、解题代码

以下是使用Edmonds-Karp算法解决最大流问题的Python代码示例:
from queue import Queue  
  
def edmonds_karp(graph, source, sink):  
    # 初始化剩余容量和流量  
    residual_graph = {u: {v: c for v, c in graph[u].items()} for u in graph}  
    flow = {u: 0 for u in graph}  
      
    # BFS寻找增广路径  
    def bfs():  
        visited = {u: False for u in graph}  
        parent = {u: None for u in graph}  
        path_flow = {u: 0 for u in graph}  
          
        queue = Queue()  
        queue.put(source)  
        visited[source] = True  
        path_flow[source] = float('inf')  
          
        while not queue.empty():  
            u = queue.get()  
              
            for v, c in residual_graph[u].items():  
                if c > 0 and not visited[v]:  
                    visited[v] = True  
                    parent[v] = u  
                    path_flow[v] = min(path_flow[u], c)  
                      
                    if v == sink:  
                        return parent, path_flow  
                      
                    queue.put(v)  
          
        return None, None  
      
    # 更新流量和剩余容量  
    def update_flow(parent, path_flow):  
        u = sink  
        while u != source:  
            v = parent[u]  
            residual_graph[v][u] += path_flow[sink]  
            residual_graph[u][v] -= path_flow[sink]  
            flow[v] += path_flow[sink]  
            u = v  
      
    # 主循环  
    while True:  
        parent, path_flow = bfs()  
        if parent is None:  
            break  
          
        update_flow(parent, path_flow)  
      
    return flow[sink]  
  
# 示例输入与输出  
if __name__ == "__main__":  
    n, m, source, sink = map(int, input().split())  
    graph = {u: {} for u in range(1, n+1)}  
    for _ in range(m):  
        u, v, c = map(int, input().split())  
        graph[u][v] = c  
      
    print(edmonds_karp(graph, source, sink))

四、算法分析

        Edmonds-Karp算法是基于增广路径的最大流算法。它使用BFS来寻找从源点到汇点的增广路径,并沿着该路径更新流量和剩余容量。算法的时间复杂度为O(V*E^2),其中V是节点的数量,E是边的数量。虽然这个算法不是最高效的,但它的实现相对简单,适合用于理解最大流问题的基本概念。


五、总结

        通过解决最大流问题,我们学习了网络流算法中的基本概念和算法实现。最大流算法在多个领域都有广泛的应用,可以帮助我们优化资源分配和运输路线。在力扣上刷题的过程中,我们不仅提高了自己的编程能力,还深入理解了网络流算法的原理和应用。

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

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

相关文章

linux(阿里云)安装pytorch

目录 环境 安装步骤 1 检查python3和pip3是否已经安装 2 安装pytorch 3 安装完毕,检查pytorch版本 环境 阿里云 ubuntu 22.04 UEFI版 64位 安装步骤 1 检查python3和pip3是否已经安装 输入下面两条指令: python3 --version pip --version 检…

计算机的历史以及原理

一、计算机发展历史 计算机的历史可以追溯到几个世纪前,但现代计算机的起源和发展主要经历了以下几个重要阶段: 1. 机械计算设备:早在17世纪,人们就开始尝试制造可以进行基本数学运算的设备。例如,法国哲学家兼数学家Blaise Pascal在1642年发明了Pascalene,这是一种用于…

windows vs 自己编译源码 leveldb 然后使用自己编译的文件

1 准备源码文件 1.1 第一种方法 git下载源码 vs项目中git leveldb源码和git third_party googletest-CSDN博客 1.2 第二种方法 手动下载 然后把第三方的源码下载 复制到 third_party 对应的文件夹中 没有文件夹 third_party -> powershell mkdir third_party 2 编译lev…

Linux内核-时间子系统(时钟中断)专题汇总

文章目录 概要一、专题汇总1.1、优秀系列博文1.2、时间子系统1.3、高精度定时器hrtimer1.4、RTC硬件芯片驱动 概要 中断机制是计算机系统的重要组成部分,在Linux中也不例外,中断按照来源分为硬中断和软中断,而硬中断根据硬件范围分为外中断和…

VUE框架详解

一、Vue简介 作者:尤雨溪 vue官网地址 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,…

C++_二叉搜索树

目录 1、二叉搜索树的概念 2、二叉搜索树的插入 3、二叉搜索树的查找 4、二叉搜索树的删除 5、二叉搜索树的拷贝构造与析构 前言: 二叉搜索树是一颗二叉树,他跟普通的二叉树的区别在于:二叉搜索树的节点是按照特定规则进行摆放的。二叉搜…

数字图像处理技术

源码在末尾 ————————————————————————— 材料 有需要源码找我

Visual Studio Code连接远程MS Azure服务器的方法

1. 开启远程MS Azure服务器 Step 1.1. 登录MS Azure账号,https://azure.microsoft.com/en-us/get-started/azure-portal Step 1.2. 开启远程MS Azure服务器 2. 通过Visual Studio Code连接MS Azure远程服务器 Step 2.1. 安装Remote-SSH Extension Step 2.2. 选择…

使用bpmn-js 配置颜色

本篇文章介绍如何使用bpmn-js给图例配置颜色。该示例展示了如何向BPMN图添加颜色的多种不同方法。 通过层叠设置颜色 这种方式比较简单,直接通过设置图片的CSS层叠样式就可实现。 .highlight-overlay {background-color: green; /* color elements as green */opa…

Linux_进程地址空间

我们用c语言写的程序,经过编译后形成可执行程序存放在硬盘。当运行该程序时,操作系统将该程序加载到内存中,创建进程控制块,变为进程,然后开始执行该程序。大家是否想过,操作系统是如何加载的呢&#xff1b…

164基于matlab的奇异值分解、小波降噪、zoom细化

基于matlab的奇异值分解、小波降噪、zoom细化。程序已调通,可直接运行。 164 奇异值分解 小波降噪 zoom细化 (xiaohongshu.com)

ESP32学习(1)——环境搭建

使用的ESP32板子如下图所示 它可以用Arduino 软件,基于C语言开发。但是,在这里,我是用Thonny软件,基于micro_python对其进行开发。 1.安装Thonny Thonny的软件安装包,可以去它官网上下载。Thonny, Python IDE for begi…

春节专题|产业7问:区块链厂商的现在和未来——基础设施厂商

2023转瞬即逝,不同于加密领域沉寂一整年后在年末集中爆发,对于我国的区块链厂商而言,稳中求胜才是关键词,在平稳发展的基调下,产业洗牌也悄无声息的到来。 从产业总体而言,在经过了接近3年的快速发展后&…

利用C语言编程从数学角度揭秘2024春晚刘谦魔术《守岁共此时》

目录 一、魔术《守岁共此时》的步骤 二、揭秘魔术《守岁共此时》 三、数学模型约瑟夫问题(约瑟夫环) 四、编程复现魔术《守岁共此时》 五、程序运行结果 一、魔术《守岁共此时》的步骤 在今年的春晚里,魔术师刘谦表演了一个和纸牌相关的…

AndroidStdio修改安卓模拟器的安装位置

AndroidStdio修改安卓模拟器的安装位置 1.删除原有的虚拟机 可以直接删除这个avd文件,放心大胆删除 在这个目录下可以看到.avd文件和.ini文件。.avd占了我10G.上图是我转移.avd后截的。发现这个.ini文件,.ini文件就是配置文件,就像mysql安装…

HTML快速入门教程

HTML:超文本标记语言(Hyper Text Markup Language),是通过标签的形式将内容组织起来然后共享到网络之上供其他电脑访问查看。 大家可以思考一下,怎么将自己电脑上的文件或图片共享给其他电脑? 这时候会说通…

C++ //练习 6.7 编写一个函数,当它第一次被调用时返回0,以后每次被调用返回值加1。

C Primer(第5版) 练习 6.7 练习 6.7 编写一个函数,当它第一次被调用时返回0,以后每次被调用返回值加1。 环境:Linux Ubuntu(云服务器) 工具:vim 代码块 /**********************…

【MySQL进阶之路】千万级数据删除导致的慢查询SQL调优实战

欢迎关注公众号(通过文章导读关注:【11来了】),及时收到 AI 前沿项目工具及新技术的推送! 在我后台回复 「资料」 可领取编程高频电子书! 在我后台回复「面试」可领取硬核面试笔记! 文章导读地址…

Pandas数据库大揭秘:read_sql、to_sql 参数详解与实战篇【第81篇—Pandas数据库】

Pandas数据库大揭秘:read_sql、to_sql 参数详解与实战篇 Pandas是Python中一流的数据处理库,而数据库则是数据存储和管理的核心。将两者结合使用,可以方便地实现数据的导入、导出和分析。本文将深入探讨Pandas中用于与数据库交互的两个关键方…

2024,欢迎来到性价比时代

「不是XX买不起,而是YY更有性价比。」——翻开过去一年的商业消费史,这句话几乎可以贯穿始终。年轻消费者们追求性价比的眼光一旦定型,一些品牌过去被品质生活、消费升级包装出来的华丽外壳,很容易一击就碎。 胜出的「性价比之王…