代碼隨想錄算法訓練營第五十八天 | 1.拓撲排序精講 2.dijkstra(樸素版)精講 卡碼網117.網站構建 卡碼網47.參加科學大會

1.拓撲排序精講

題目鏈接:117. 軟件構建

文章講解:代碼隨想錄

思路:

把有向無環圖進行線性排序的算法都可以叫做拓撲排序。

實現拓撲排序的算法有兩種:卡恩算法(BFS)和DFS,以下BFS的實現思路。

節點0 的入度為0 出度為2, 也就是沒有邊指向它,而它有兩條邊是指出去的。節點的入度表示有多少條邊指向它,節點的出度表示有多少條邊從該節點出發。做拓撲排序的時候,應該優先找入度為0的節點,只有入度為0,它才是出發節點。

拓撲排序的過程,兩步:

(1)找到入度為0 的節點,加入結果集

(2)將該節點從圖中移除

循環以上兩步,直到 所有節點都在圖中被移除了。

如果發現結果集元素個數不等于圖中節點個數,我們就可以認定圖中一定有有向環,這也是拓撲排序判斷有向環的方法。

2.dijkstra(樸素版)精講

題目鏈接:47. 參加科學大會(第六期模擬筆試)

文章講解:代碼隨想錄

思路:給出一個有向圖,一個起點,一個終點,問起點到終點的最短路徑。

最短路算法中的 dijkstra 算法:在有權圖(權值非負數)中求從起點到其他節點的最短路徑算法。

(dijkstra 算法可以同時求起點到所有節點的最短路徑,權值不能為負數)

dijkstra 算法 同樣是貪心的思路,不斷尋找距離 源點最近的沒有訪問過的節點。

dijkstra三部曲:

第一步,選源點到哪個節點近且該節點未被訪問過

第二步,該最近節點被標記訪問過

第三步,更新非訪問節點到源點的距離(即更新minDist數組)

在dijkstra算法中,minDist數組用來記錄每一個節點距離源點的最小距離。

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

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

相關文章

Qt實現語言切換的完整方案

在Qt中實現語言動態切換需要以下幾個關鍵步驟,我將提供一個完整的實現方案: 一、準備工作 在代碼中使用tr()標記所有需要翻譯的字符串 cpp button->setText(tr("Submit")); 創建翻譯文件 在.pro文件中添加: qmake TRANSLATION…

面試中被問到mybatis與jdbc有什么區別怎么辦

1. 核心區別 維度JDBCMyBatis抽象層級底層API,直接操作數據庫高層持久層框架,封裝JDBC細節代碼量需要手動編寫大量樣板代碼(連接、異常處理等)通過配置和映射減少冗余代碼SQL管理SQL嵌入Java代碼,維護困難SQL與Java代…

用于協同顯著目標檢測的小組協作學習 2021 GCoNet(總結)

摘要 一 介紹 問題一:以往的研究嘗試利用相關圖像之間的一致性,通過探索不同的共享線索[12, 13, 14]或語義連接[15, 16, 17],來助力圖像組內的共同顯著目標檢測(CoSOD),什么意思? 一方面是探…

OpenCV 圖形API(62)特征檢測-----在圖像中查找最顯著的角點函數goodFeaturesToTrack()

操作系統:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 編程語言:C11 算法描述 確定圖像上的強角點。 該函數在圖像或指定的圖像區域內找到最顯著的角點,如文獻[240]中所述。 函數使用 cornerMinEigenVal 或 cor…

MySQL引擎分類與選擇、SQL更新底層實現、分庫分表、讀寫分離、主從復制 - 面試實戰

MySQL引擎分類與選擇、SQL更新底層實現、分庫分表、讀寫分離、主從復制 - 面試實戰 故事背景: 今天,我們模擬一場互聯網大廠Java求職者的面試場景。面試官將針對MySQL的核心技術點進行提問,涵蓋MySQL引擎分類與選擇、SQL更新底層實現、分庫…

如何確保微型導軌的質量穩定?

微型導軌在精密機械中扮演著至關重要的角色,它們不僅影響設備的性能,還決定了產品的壽命。那么,如何通過一些關鍵步驟來提高微型導軌的穩定性呢? 1、嚴格篩選供應商:選擇具備高品質保證能力的供應商,確保原…

Golang編程拒絕類型不安全

簡介 在 Go 中,標準庫提供了多種容器類型,如 list、ring、heap、sync.Pool 和 sync.Map。然而,這些容器默認是類型不安全的,即它們可以接受任何類型的值,這可能導致運行時錯誤。為了提升代碼的類型安全性和可維護性&am…

什么是 JSON?學習JSON有什么用?在springboot項目里如何實現JSON的序列化和反序列化?

作為一個學習Javaweb的新手,理解JSON的序列化和反序列化非常重要,因為它在現代Web開發,特別是Spring Boot中無處不在。 什么是 JSON? 首先,我們簡單了解一下JSON (JavaScript Object Notation)。 JSON 是一種輕量級的…

iOS/Android 使用 C++ 跨平臺模塊時的內存與生命周期管理

在移動應用開發領域,跨平臺開發已經成為一種不可忽視的趨勢。隨著智能手機市場的持續擴張,開發者需要同時滿足iOS和Android兩大主流平臺的需求,而這往往意味著重復的工作量和高昂的維護成本。跨平臺開發的目標在于通過一套代碼庫實現多平臺的支持,從而降低開發成本、加速產…

【AAudio】A2dp sink創建音頻軌道的源碼流程分析

一、AAudio概述 AAudio 是 Android 8.0(API 級別 26)引入的 C/C++ 原生音頻 API,專為需要低延遲、高性能音頻處理的應用設計,尤其適用于實時音頻應用(如音頻合成器、音樂制作工具、游戲音效等)。 1.1 主要特點 低延遲:通過減少音頻數據在內核與用戶空間之間的拷貝,直…

Spring中配置 Bean 的兩種方式:XML 配置 和 Java 配置類

在 Spring 框架中,配置 Bean 的方式主要有兩種:XML 配置 和 Java 配置類。這兩種方式都可以實現將對象注冊到 Spring 容器中,并通過依賴注入進行管理。本文將詳細介紹這兩種配置方式的步驟,并提供相應的代碼示例。 1. 使用 XML 配置的方式 步驟 創建 Spring 配置文件 創建…

海之淀攻略

家長要做的功課 家長可根據孩子情況,需要做好以下功課: 未讀小學的家長:了解小學小升初派位初中校額到校在讀小學的家長:了解小升初派位初中校額到校在讀初中的家長:了解初中校額到校 越是高年級的家長,…

BUUCTF-[GWCTF 2019]re3

[GWCTF 2019]re3 查殼,64位無殼 然后進去發現主函數也比較簡單,主要是一個長度校驗,然后有一個mprotect函數,說明應該又是Smc,然后我們用腳本還原sub_402219函數處的代碼 import idc addr0x00402219 size224 for …

sql server 開啟cdc報事務正在執行

今天開啟數據庫cdc 功能的時候提示:一個dbrole 的存儲過程,rolemember cdc db_ower, ,有事務正在進行,執行失敗。 執行多次仍然如此,開啟cdc的存儲過程是sys.sp_cdc_enable_db;查詢了一下網絡,給出的方…

2025年GPLT團體程序設計天梯賽L1-L2

目錄 1.珍惜生命 2.偷感好重 3.高溫補貼 4.零頭就抹了吧 5.這是字符串題 6.這不是字符串題 7.大冪數?編輯 8.現代戰爭?編輯 9.算式拆解 10.三點共線 11.胖達的山頭 12.被n整除的n位數 1.珍惜生命 【解析】直接輸出即可 #include<bits/stdc.h> using namespace…

promethus基礎

1.下載prometheus并解壓 主要配置prometheus.yml文件 在scrape_configs配置項下添加配置(hadoop202是主機名)&#xff1a; scrape_configs: job_name: ‘prometheus’ static_configs: targets: [‘hadoop202:9090’] 添加 PushGateway 監控配置 job_name: ‘pushgateway’…

緩存與數據庫數據一致性:旁路緩存、讀寫穿透和異步寫入模式解析

旁路緩存模式、讀寫穿透模式和異步緩存寫入模式是三種常見的緩存使用模式&#xff0c;以下是對三種經典緩存使用模式在緩存與數據庫數據一致性方面更全面的分析&#xff1a; 一、旁路緩存模式&#xff08;Cache - Aside Pattern&#xff09; 1.數據讀取流程 應用程序首先向緩…

【ESP32S3】 下載時遇到 libusb_open() failed 解決方案

之前寫過一篇 《VSCode 開發環境搭建》 的文章&#xff0c;很多小伙伴反饋說在下載固件或者配置的時候會報錯&#xff0c;提示大多是 libusb_open() failed ...... &#xff1a; 這其實是由于 USB 驅動不正確導致的&#xff0c;準確來說應該是與 ESP-IDF 中內置的 OpenOCD 需要…

ISCTF2024-misc(部分)

前言 之前寫的&#xff0c;一直沒發&#xff0c;留個記錄吧&#xff0c;萬一哪天記錄掉了起碼在csdn有個念想 1.少女的秘密花園 打開是個圖片 隨波逐流binwalk一下分離得到一個zip&#xff0c;解壓得到base_misc發現是zip 爆破得到密碼 解壓得到一個txt&#xff0c;將里面的…

word內容使用python替換

擁有一個固定的word文件&#xff0c;類似模板 比如寫一個測試計劃&#xff0c;大多數內容都是通用&#xff0c;只需要改改軟件名稱&#xff0c;人員等等&#xff0c;數量多起來的情況下就可以使用代碼 # 導入 Document 類&#xff0c;用于處理 Word 文檔 from docx import Do…