cari
Rumahpembangunan bahagian belakangTutorial PythonMenghuraikan algoritma Ford-Fulkerson dan melaksanakannya melalui Python

Algoritma Ford-Fulkerson ialah algoritma tamak yang digunakan untuk mengira trafik maksimum dalam rangkaian. Prinsipnya adalah untuk mencari laluan penambahan dengan kapasiti baki positif Selagi laluan penambahan ditemui, anda boleh terus menambah laluan dan mengira trafik. Sehingga laluan penambahan tidak lagi wujud, kadar aliran maksimum boleh diperolehi.

Terminologi algoritma Ford-Fulkerson

Baki kapasiti: Ia adalah kapasiti tolak aliran Dalam algoritma Ford-Fulkerson, baki kapasiti ialah nombor positif sebelum ia boleh terus menjadi laluan.

Rangkaian sisa: Ia adalah rangkaian dengan bucu dan tepi yang sama, menggunakan kapasiti baki sebagai kapasiti.

Laluan tambahan: Ia ialah laluan dari titik sumber ke titik penerimaan dalam graf baki, dengan kapasiti akhir 0.

Contoh prinsip algoritma Ford-Fulkerson

Konsepnya mungkin tidak begitu jelas Mari kita lihat contoh Trafik awal semua tepi rangkaian aliran ialah 0, dan terdapat had kapasiti atas yang sepadan menjadi S dan titik penerimaan ialah T. .

Ford-Fulkerson算法概念详解 Python实现Ford-Fulkerson算法

Laluan satu, baki kapasiti laluan S-A-B-T ialah 8, 9, 2, dan nilai minimum ialah 2, jadi trafik laluan satu ialah 2, dan trafik rajah rangkaian ialah 2.

Ford-Fulkerson算法概念详解 Python实现Ford-Fulkerson算法

Laluan dua, baki kapasiti laluan S-D-C-T ialah 3, 4, 5, dan nilai minimum ialah 3, jadi kita boleh meningkatkan trafik sebanyak 3, dan trafik rangkaian ialah 5.

Ford-Fulkerson算法概念详解 Python实现Ford-Fulkerson算法

Laluan tiga, baki kapasiti laluan S-A-B-D-C-T ialah 6, 7, 7, 1, 2, dan nilai minimum ialah 1, jadi trafik meningkat sebanyak 1, dan trafik rangkaian ialah 6.

Ford-Fulkerson算法概念详解 Python实现Ford-Fulkerson算法

Pada ketika ini, tiada kapasiti baki positif, dan aliran maksimum rangkaian aliran ini ialah 6.

Python melaksanakan algoritma Ford-Fulkerson

from collections import defaultdict

class Graph:

    def __init__(self, graph):
        self.graph = graph
        self. ROW = len(graph)

    def searching_algo_BFS(self, s, t, parent):

        visited = [False] * (self.ROW)
        queue = []

        queue.append(s)
        visited[s] = True

        while queue:

            u = queue.pop(0)

            for ind, val in enumerate(self.graph[u]):
                if visited[ind] == False and val > 0:
                    queue.append(ind)
                    visited[ind] = True
                    parent[ind] = u

        return True if visited[t] else False

    def ford_fulkerson(self, source, sink):
        parent = [-1] * (self.ROW)
        max_flow = 0

        while self.searching_algo_BFS(source, sink, parent):

            path_flow = float("Inf")
            s = sink
            while(s != source):
                path_flow = min(path_flow, self.graph[parent[s]][s])
                s = parent[s]

            max_flow += path_flow

            v = sink
            while(v != source):
                u = parent[v]
                self.graph[u][v] -= path_flow
                self.graph[v][u] += path_flow
                v = parent[v]

        return max_flow

graph = [[0, 8, 0, 0, 3, 0],
         [0, 0, 9, 0, 0, 0],
         [0, 0, 0, 0, 7, 2],
         [0, 0, 0, 0, 0, 5],
         [0, 0, 7, 4, 0, 0],
         [0, 0, 0, 0, 0, 0]]

g = Graph(graph)

source = 0
sink = 5

print("Max Flow: %d " % g.ford_fulkerson(source, sink))

Atas ialah kandungan terperinci Menghuraikan algoritma Ford-Fulkerson dan melaksanakannya melalui Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Artikel ini dikembalikan pada:网易伏羲. Jika ada pelanggaran, sila hubungi admin@php.cn Padam
如何实现C#中的贪心算法如何实现C#中的贪心算法Sep 19, 2023 am 11:48 AM

如何实现C#中的贪心算法贪心算法(Greedyalgorithm)是一种常用的问题求解方法,它每次选择当前最优的解决方案,希望能够获得全局最优解。在C#中,我们可以利用贪心算法解决许多实际问题。本文将介绍如何在C#中实现贪心算法,并提供具体的代码示例。一、贪心算法的基本原理贪心算法的基本思想是每次都选择当前最优的解决方案,而不考虑后续步骤可能的影响。这种思

如何使用贪心算法在PHP中实现最少硬币找零问题的高效解决方案?如何使用贪心算法在PHP中实现最少硬币找零问题的高效解决方案?Sep 19, 2023 am 10:22 AM

如何使用贪心算法在PHP中实现最少硬币找零问题的高效解决方案?引言:在日常生活中,我们经常需要找零,尤其是在购物或交易时。要尽可能少地使用硬币,找零金额应该使用尽可能少的硬币进行组合。在计算机编程中,我们可以使用贪心算法来解决这个问题,以得到一个高效的解决方案。本文将介绍如何在PHP中使用贪心算法实现最少硬币找零问题的高效解决方案,并提供相应的代码示

解析Ford-Fulkerson算法并通过Python实现解析Ford-Fulkerson算法并通过Python实现Jan 22, 2024 pm 08:09 PM

Ford-Fulkerson算法是贪心算法,用于计算网络中的最大流量。其原理是找到剩余容量为正的增广路径,只要找到增广路径,就可以继续增加路径和计算流量。直到增广路径不再存在,这时就能得出最大流量。Ford-Fulkerson算法的术语剩余容量:就是将容量减去流量,在Ford-Fulkerson算法中剩余容量是正数,才能继续作为路径。残差网络:是一个具有相同顶点和边的网络,使用残差容量作为容量。增广路径:是残差图中从源点到接收点的路径,最终容量为0。Ford-Fulkerson算法原理示例可能概

如何使用Python实现贪心算法?如何使用Python实现贪心算法?Sep 19, 2023 am 11:43 AM

如何使用Python实现贪心算法?贪心算法(GreedyAlgorithm)是一种简单而有效的算法,适用于解决那些具有最优子结构性质的问题。它在每一步选择中都采取当前状态下最优的选择,希望能够找到全局最优解。在本篇文章中,将介绍如何使用Python实现贪心算法,并附带具体的代码示例。一、贪心算法的基本思想贪心算法的基本思想是每一步选择当前状态下的最优解,然

如何使用PHP编写贪心算法如何使用PHP编写贪心算法Jul 07, 2023 pm 03:45 PM

如何使用PHP编写贪心算法贪心算法(Greedyalgorithm)是一种简单而有效的算法,用于解决一类最优化问题。它的基本思想是在每个步骤中都做出当前看起来最好的选择,而不考虑未来的后果。本文将介绍如何使用PHP编写贪心算法,并提供相关的代码示例。一、问题描述在讲解贪心算法之前,先来定义一个具体的问题,以便更好地理解。假设有一组任务,每个任务都有一个开始

C++中的贪心算法及其实现C++中的贪心算法及其实现Aug 22, 2023 am 10:04 AM

贪心算法是一种常用的算法思想,在许多问题中都有着广泛的应用。其核心思想是在做出每一步的决策时,只考虑眼前最优解,而不考虑长远的影响。在C++中,贪心算法的实现经常会涉及到排序、数据处理等基本操作。下面,我们将针对几个典型的问题,介绍贪心算法的思路及其在C++中的实现。1.活动安排问题给定一组活动,每个活动有其开始时间和结束时间,同时一个人一次只能参加一个活动

贪心算法的C/C++程序,用于找到最少硬币数量贪心算法的C/C++程序,用于找到最少硬币数量Sep 19, 2023 pm 11:01 PM

贪心算法是一种用于寻找给定问题的最优解决方案的算法。贪婪算法的工作原理是找到每个部分的局部最优解(问题的一部分的最优解),因此表明可以找到全局最优解。在这个问题中,我们将使用贪婪算法算法来找到可以组成给定总和的最小硬币/纸币数量。为此,我们将考虑所有有效的硬币或纸币,即面额为{1,2,5,10,20,50,100,200,500,2000}。我们需要返回需要补足总和的硬币/纸币的数量。让我们举几个例子来更好地理解上下文-示例1-Input:1231Output:7说明-我们需要两张500卢比纸币

如何使用java实现贪心算法如何使用java实现贪心算法Sep 19, 2023 am 11:13 AM

如何使用Java实现贪心算法贪心算法(GreedyAlgorithm)是一种解决问题的算法思想,其特点是每一步都选择当前最优解,希望通过每个局部最优解最终达到全局最优解。在解决一些最优化问题或者某些特定的问题时,贪心算法的简单而高效的特性使其成为一种常用的算法。本文将介绍如何使用Java实现贪心算法,并提供具体的代码示例。一、贪心算法的基本思想贪心算法的基

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.