Home Common Problem What is the principle of floyd algorithm?

What is the principle of floyd algorithm?

Aug 21, 2020 pm 02:22 PM

The principle of Floyd's algorithm is an algorithm that uses the idea of ​​dynamic programming to find the shortest path between multiple source points in a given weighted graph. It is similar to the Dijkstra algorithm. It is also an algorithm that uses the idea of ​​dynamic programming to find the shortest path between multiple source points in a given weighted graph. Algorithm for finding the shortest path in a weighted graph.

What is the principle of floyd algorithm?

Floyd algorithm Also known as the interpolation method, it is a method that uses the idea of ​​dynamic programming to find multiple sources in a given weighted graph The algorithm for the shortest path between points is similar to Dijkstra's algorithm. The algorithm is named after Robert Floyd, one of the founders, winner of the 1978 Turing Award, and professor of computer science at Stanford University

In computer science, the Floyd-Warshall algorithm is a Algorithm for finding shortest paths in weighted graphs with positive or negative edge weights (but no negative periods). A single execution of the algorithm will find the length (weighted) of the shortest path between all pairs of vertices. Although it does not return details of the path itself, the path can be reconstructed with simple modifications to the algorithm. Versions of this algorithm can also be used to find the transitive closure of a relation R, or (related to the Schulze voting system) the widest path between all pairs of vertices in a weighted graph.

The Floyd-Warshall algorithm is an example of dynamic programming and was published in its currently accepted form by Robert Floyd in 1962. However, it is essentially the same algorithm for finding transitive closures of graphs published previously by Bernard Roy in 1959 and Stephen Warshall in 1962, and is closely related to Kleene's algorithm in 1956) for converting deterministic finite automata Convert to regular expression. The modern formulation of the algorithm as three nested for loops was first described by Peter Ingerman in 1962.

This algorithm is also called Floyd algorithm, Roy-Warshall algorithm, Roy-Floyd algorithm or WFI algorithm.

Core Idea Edit

1. Path Matrix

Find every two of a graph’s weight matrix Shortest path matrix between points.

Starting from the weighted adjacency matrix A=[a(i,j)] n×n of the graph, recursively perform n updates, that is, from the matrix D(0)=A, according to a formula, construct The matrix D(1) is obtained; and the same formula is used to construct D(2) from D(1);...; finally, the matrix D(n) is constructed from D(n-1) using the same formula. The elements in row i and column j of matrix D(n) are the shortest path length from vertex i to vertex j. D(n) is called the distance matrix of the graph. At the same time, a successor node matrix path can also be introduced to record the distance between two points. the shortest path.

Use relaxation technology (relaxation operation) to relax all other points between i and j. So the time complexity is O(n^3);

2. State transition equation

The state transition equation is as follows: map[i,j]:=min {map[i,k] map[k,j],map[i,j]};

map[i,j] represents the shortest distance from i to j, and K is the exhaustive list of i,j Breakpoint, the initial value of map[n,n] should be 0, or follow the meaning of the question.

Of course, if this road is not accessible, special processing must be performed, for example, there is no map[i,k] road.

Algorithm process editor

1, start from any unilateral path. The distance between all two points is the weight of the edge. If there is no edge connecting the two points, the weight is infinite.

2, for each pair of vertices u and v, see if there is a vertex w such that the path from u to w to v is shorter than the known path. If so update it.

Represent the graph as an adjacency matrix G. If there is a path from Vi to Vj, then G[i][j]=d, d represents the length of the path; otherwise G[i][j ] = infinity. Define a matrix D to record the information of the inserted point. D[i][j] represents the point that needs to be passed from Vi to Vj. Initialize D[i][j]=j. Insert each vertex into the graph and compare the distance after the insertion with the original distance, G[i][j] = min( G[i][j], G[i][k] G[k][j] ), if the value of G[i][j] becomes smaller, then D[i][j]=k. G contains the information of the shortest road between two points, while D contains the information of the shortest path.

For example, we want to find the path from V5 to V1. According to D, if D(5,1)=3, it means that the path from V5 to V1 passes through V3 is {V5,V3,V1}. If D(5,3)=3, it means that V5 and V3 are directly connected. If D (3,1)=1, indicating that V3 and V1 are directly connected.

Time complexity and space complexity editing

Time complexity: O(n^3);

Space complexity:O(n ^2)

Advantages and Disadvantages Analysis and Edit

Floyd algorithm is suitable for APSP (All Pairs Shortest Paths, multi-source shortest path). It is a dynamic programming algorithm, dense The graph has the best effect, and the edge weights can be positive or negative. This algorithm is simple and effective. Due to the compact triple loop structure, for dense graphs, the efficiency is higher than executing |V| times of Dijkstra's algorithm and higher than executing |V| times of SPFA algorithm.

Advantages: Easy to understand, can calculate the shortest distance between any two nodes, and the code is simple to write.

Disadvantages: The time complexity is relatively high and it is not suitable for calculating large amounts of data.

The above is the detailed content of What is the principle of floyd algorithm?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

deepseek web version official entrance deepseek web version official entrance Mar 12, 2025 pm 01:42 PM

The domestic AI dark horse DeepSeek has risen strongly, shocking the global AI industry! This Chinese artificial intelligence company, which has only been established for a year and a half, has won wide praise from global users for its free and open source mockups, DeepSeek-V3 and DeepSeek-R1. DeepSeek-R1 is now fully launched, with performance comparable to the official version of OpenAIo1! You can experience its powerful functions on the web page, APP and API interface. Download method: Supports iOS and Android systems, users can download it through the app store; the web version has also been officially opened! DeepSeek web version official entrance: ht

In-depth search deepseek official website entrance In-depth search deepseek official website entrance Mar 12, 2025 pm 01:33 PM

At the beginning of 2025, domestic AI "deepseek" made a stunning debut! This free and open source AI model has a performance comparable to the official version of OpenAI's o1, and has been fully launched on the web side, APP and API, supporting multi-terminal use of iOS, Android and web versions. In-depth search of deepseek official website and usage guide: official website address: https://www.deepseek.com/Using steps for web version: Click the link above to enter deepseek official website. Click the "Start Conversation" button on the homepage. For the first use, you need to log in with your mobile phone verification code. After logging in, you can enter the dialogue interface. deepseek is powerful, can write code, read file, and create code

How to solve the problem of busy servers for deepseek How to solve the problem of busy servers for deepseek Mar 12, 2025 pm 01:39 PM

DeepSeek: How to deal with the popular AI that is congested with servers? As a hot AI in 2025, DeepSeek is free and open source and has a performance comparable to the official version of OpenAIo1, which shows its popularity. However, high concurrency also brings the problem of server busyness. This article will analyze the reasons and provide coping strategies. DeepSeek web version entrance: https://www.deepseek.com/DeepSeek server busy reason: High concurrent access: DeepSeek's free and powerful features attract a large number of users to use at the same time, resulting in excessive server load. Cyber ​​Attack: It is reported that DeepSeek has an impact on the US financial industry.