圖論:floyed算法

Floyd 算法是一種用于尋找加權圖中所有頂點對之間最短路徑的經典算法,它能夠處理負權邊,但不能處理負權環。即如果邊權有負數,切負權邊與其他邊構成了環就不能用該算法。該算法的時間復雜度為?\(O(V^3)\),其中?V?是圖中頂點的數量。

算法核心思想

Floyd 算法的核心思想是動態規劃。它通過逐步引入中間頂點來不斷更新任意兩點之間的最短路徑。具體來說:

  1. 初始化:假設圖用鄰接矩陣?dist[][]?表示,其中?dist[i][j]?表示頂點?i?到頂點?j?的初始距離。如果?i?和?j?之間沒有直接邊,則?dist[i][j]?為無窮大(通常用一個很大的數表示)。
  2. 動態規劃更新:對于每一個中間頂點?k,檢查是否可以通過?k?作為中間點來縮短從?i?到?j?的路徑。即更新條件為: \(\text{dist}[i][j] = \min(\text{dist}[i][j], \text{dist}[i][k] + \text{dist}[k][j])\)
  3. 重復步驟 2:依次考慮所有中間頂點?k?從?0?到?V-1,最終得到所有頂點對之間的最短路徑。

例題

題目描述:所有城市間的最短路徑

有?n?個城市和?m?條道路,每條道路連接兩個城市并具有一定的長度。請計算任意兩個城市之間的最短路徑長度。如果兩個城市之間無法到達,則輸出?-1

輸入格式

  • 第一行包含兩個整數?n?和?m(1 ≤ n ≤ 200,0 ≤ m ≤ n(n-1)/2)。
  • 接下來的?m?行,每行包含三個整數?u,?v,?w,表示城市?u?到城市?v?有一條長度為?w?的雙向道路(1 ≤ u, v ≤ n,1 ≤ w ≤ 1000)。

輸出格式

  • 輸出一個?n × n?的矩陣,其中第?i?行第?j?列的元素表示城市?i?到城市?j?的最短路徑長度。如果無法到達,輸出?-1

樣例:

輸入

4 4
1 2 1
2 3 2
3 4 3
1 4 10

輸出

0 1 3 6
1 0 2 5
3 2 0 3
6 5 3 0

答案?

#include <iostream>
#include<cstring>
#include <algorithm>
using namespace std;const int INF = 0x3f3f3f3f;
int n,m;
int graph[205][205];
int main() {cin>>n>>m;//距離初始化為最大值memset(graph,INF,sizeof(graph));//自己到自己的距離為0for (int i = 1; i <= n; i++) {graph[i][i] = 0;}int u,v,w;for(int i=0;i<m;i++){cin>>u>>v>>w;graph[u][v]=min(graph[u][v],w);graph[v][u]=min(graph[v][u],w);}//floyed算法for(int k=1;k<=n;k++){  //中樞點for(int i=1;i<=n;i++){  //起點for(int j=1;j<=n;j++){  //終點if(graph[i][k]+graph[k][j]<graph[i][j]){graph[i][j]=graph[i][k]+graph[k][j];}}}}for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){if(graph[i][j]==INF){cout<<-1<<" ";}else{cout<<graph[i][j]<<" ";}}cout<<endl;}return 0;
}

應用場景

  • 計算圖中所有頂點對之間的最短路徑。
  • 檢測圖中是否存在負權環。
  • 計算傳遞閉包(Transitive Closure)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/907157.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/907157.shtml
英文地址,請注明出處:http://en.pswp.cn/news/907157.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

STM32之看門狗(IWDG)

一、看門狗外設的原理與應用 背景說明 隨著單片機的發展&#xff0c;單片機在家用電器、工業自動化、生產過程控制、智能儀器儀表等領域的應用越來越廣泛。然而處于同一電力系統中的各種電氣設備通過電或磁的聯系彼此緊密相連&#xff0c;相互影響&#xff0c;由于運行方式的…

#RabbitMQ# 消息隊列進階

目錄 消息可靠性 一 生產者的可靠性 1 生產者的重連 2 生產者的確認 (1 Confirm* (2 Return 二 MQ的可靠性 1 數據持久化 2 Lazy Queue* 三 消費者的可靠性 1 消費者確認機制 2 消費失敗處理 3 業務冪等性 四 延遲消息 消息可靠性 在消息隊列中&#xff0c;可靠性…

《計算機組成原理》第 10 章 - 控制單元的設計

目錄 10.1 組合邏輯設計 10.1.1 組合邏輯控制單元框圖 10.1.2 微操作的節拍安排 10.1.3 組合邏輯設計步驟 10.2 微程序設計 10.2.1 微程序設計思想的產生 10.2.2 微程序控制單元框圖及工作原理 10.2.3 微指令的編碼方式 1. 直接編碼&#xff08;水平型&#xff09; 2.…

AstroNex空間任務智能控制研究與訓練數據集

數據集概述 AstroNex空間任務智能控制研究與訓練數據集是朗迪鋒科技基于Multiverse平臺精心打造的首個全面覆蓋航天器智能控制全周期的綜合數據集產品。該數據集匯集了軌道動力學、姿態控制、機器視覺、環境感知等多維度數據&#xff0c;為航天器智能算法研發提供豐富的訓練與…

??3D 幾何建模工具庫?Open CASCADE(OCCT)簡單介紹。

??Open CASCADE&#xff08;OCCT&#xff09;?? 的新手&#xff0c;我會用最簡單的方式幫你理解它是什么、能做什么&#xff0c;以及如何快速上手。 ??1. OCCT 是什么&#xff1f;?? ??一句話定義??&#xff1a;OCCT 是一個開源的 ??3D 幾何建模工具庫??&…

[7-1] ADC模數轉換器 江協科技學習筆記(14個知識點)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 DMA&#xff08;Direct Memory Access&#xff0c;直接內存訪問&#xff09;是一種硬件特性&#xff0c;它允許某些硬件子系統直接訪問系統的內存&#xff0c;而無需CPU的介入。這樣&#xff0c;CPU就可以處理其他任務&#xff0c;從而提高系…

篇章三 基礎——不可變類

目錄 1.是什么 2.為什么 3.怎么做 4.構造詳細的不可變類示例: 5.補充 5.1 Java標準庫中的不可變類 5.2 構造不可變類進階 1.對象包含嵌套的引用類型字段 2. 大型對象采用不可變類時,需考慮性能影響。 2.1 內存占用問題 2.2 垃圾回收壓力 2.3 復制開銷 2.4 優化策…

cuda ncu section 含義解釋

NVIDIA Nsight Compute (NCU) 是用于分析 CUDA 程序性能的工具&#xff0c;通過 Sections 組織性能指標。用戶提供的 24 個 Sections 涵蓋了計算、內存、調度、互連和可視化等方面。本報告詳細解釋每個 Section 的含義、用途及相關分析場景。 Sections 詳細解析 C2CLink 含義&…

NGINX HTTP/2 全面指南開啟、調優與實戰

一、為什么要用 HTTP/2&#xff1f; 多路復用&#xff08;Multiplexing&#xff09; 單連接上可并發交錯發送多路請求&#xff0c;避免了 HTTP/1.x 中的隊頭阻塞&#xff08;Head-Of-Line Blocking&#xff09;。頭部壓縮&#xff08;HPACK&#xff09; 對 HTTP 頭部字段進行高…

手寫簡單的tomcat

首先&#xff0c;Tomcat是一個軟件&#xff0c;所有的項目都能在Tomcat上加載運行&#xff0c;Tomcat最核心的就是Servlet集合&#xff0c;本身就是HashMap。Tomcat需要支持Servlet&#xff0c;所以有servlet底層的資源&#xff1a;HttpServlet抽象類、HttpRequest和HttpRespon…

智能體賦能效率,企業知識庫沉淀價值:UMI企業智腦的雙輪驅動!

智能體企業知識庫&#xff1a;UMI企業智腦的核心功能與價值 在人工智能技術飛速發展的今天&#xff0c;企業智能化轉型已經成為不可逆轉的趨勢。作為企業級AI智能體開發平臺的佼佼者&#xff0c;優秘智能推出的UMI企業智腦&#xff0c;以其強大的智能體開發能力和全面的企業知…

與 PyCharm 官方溝通解決開發環境問題記錄(進展:官方已推出2個新的修復版本)

??????主題&#xff1a;有關 PyCharm 中終端和環境激活問題的反饋&#xff1a;PY-81233 前言 目前進展&#xff1a; 官方已有2個修復版本推出測試。 更新方法&#xff1a; 使用JetBrains Toolbox App&#xff0c;如下圖所示&#xff0c;從“其他版本”進入查看更新。…

LINUX安裝運行jeelowcode后端項目(命令行)

環境準備 運行環境&#xff1a;JDK1.8開發工具&#xff1a; Idea、Maven默認已啟動中間件&#xff1a;&#xff08;推薦使用寶塔&#xff09;Mysql8.0、Redis、Minio第一步&#xff1a;下載JeelowCode項目并導入IDEA中 第二步&#xff1a;導入數據庫文件到mysql中&#xff0c;…

Android開機向導定制(2)開機向導配置

先貼lineage_wizard_script_user.xml的代碼&#xff1a; <WizardScript xmlns:wizard"http://schemas.android.com/apk/res/com.google.android.setupwizard"wizard:firstAction"welcome"><WizardAction wizard:uri"intent:#Intent;actiono…

守護電動“心臟”!仿真APP在汽車電池包隨機振動分析中的應用

汽車電動化、智能化、綠色化發展已成為全球各國應對氣候變化、實現低碳發展的共同選擇。在此背景下&#xff0c;新能源汽車持續高速發展。電池包作為新能源汽車的“心臟”&#xff0c;是其主要動力來源&#xff0c;直接影響車輛的續航里程與行駛安全。電池包結構的安全可靠性對…

實習面經(JAVA)

目錄 鎖升級 notify和notifyAll區別 Sleep和Wait的區別 ArrayList和ListedList區別 HashMap擴容原理 ConcurrentHashMap StringBuffer 和 StringBuilder 事務等級 索引結構 三次握手四次揮手&#xff0c;為什么是三次和四次 Java中重寫和重載的區別和應用場景 ArrayLis…

計算機網絡-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx

文章目錄 WebSocketDNS什么是dns域名解析底層協議 cookie/sessionToken/JWTNginx WebSocket 一種網絡通信協議&#xff0c;允許在單個 TCP&#xff08;半雙工&#xff09; 連接上進行全雙工通信&#xff08;客戶端和服務器可同時雙向傳輸數據&#xff09;。 HTTP是基于請求-響…

單片機如何快速實現查看實時數據

在用 Keil 做調試的時候&#xff0c;最讓人頭禿的是什么&#xff1f; 不是寫代碼的BUG&#xff0c;而是&#xff1a;這個條件變量是什么情況&#xff1f;為什么沒進入這個判斷&#xff1f;我代碼跑到哪里了&#xff1f; 其實本質上都是通過變量判斷代碼的執行順序有沒有問題 …

vue3:橫線無限滾動(向左/向右),自定義UI

子組件 <template><div class"single-scroll-container" ref"container" mouseenter"pause" mouseleave"resume"><divclass"single-scroll-content":style"{ transform: translateX(${translateX}px) }…

Anthropic公司近日發布了兩款新一代大型語言模型Claude Opus 4與Claude Sonnet 4

每周跟蹤AI熱點新聞動向和震撼發展 想要探索生成式人工智能的前沿進展嗎&#xff1f;訂閱我們的簡報&#xff0c;深入解析最新的技術突破、實際應用案例和未來的趨勢。與全球數同行一同&#xff0c;從行業內部的深度分析和實用指南中受益。不要錯過這個機會&#xff0c;成為AI領…