簡化您的工作流程:搜尋 miniwebtool。
添加插件
主頁 > 數學 > 進階數學計算 > 拓撲排序計算機
 

拓撲排序計算機

使用 Kahn 演算法或 DFS 計算有向無環圖 (DAG) 的拓撲排序。支援檢測環路、報告環路路徑、建立並行執行分層視圖、支援字典序最小排序,並在互動式圖表上動畫演示每個步驟。

拓撲排序計算機
邊格式:A -> B(也接受 , =>, :)。最多 80 個頂點 / 800 條邊。
Kahn 演算法(字典序)提供唯一且可復現的順序。DFS 後序遍歷是經典的深度優先方法。

Embed 拓撲排序計算機 Widget

拓撲排序計算機

拓撲排序計算機可計算有向無環圖 (DAG) 頂點的線性排序,使得從 u 到 v 的每條有向邊都讓 u 排在 v 之前。您可以邊列表或鄰接表的形式輸入圖形,本工具將使用 Kahn 演算法或 DFS 後序遍歷返回拓撲順序、偵測環路(並給出確切路徑)、將任務分組為並行執行層、計算有效排序的總數,並在交互式圖表上以動畫演示每個步驟。

什麼是拓撲排序?

給定一個有向圖 G = (V, E),拓撲排序(或稱拓撲順序)是其頂點 v₁, v₂, …, vₙ 的線性排列,使得對於每一條有向邊 (u → v),u 在排列中都出現在 v 之前。當且僅當圖中沒有有向環(即該圖為 DAG)時,才存在拓撲排序。排序結果通常不是唯一的:當多個頂點同時入度為零時,一個圖可以有多個有效的拓撲排序。

拓撲順序定義
V 的一個置換 (v₁, v₂, …, vn) 是拓撲排序,若且唯若
對於 E 中的每條邊 (u → v):position(u) < position(v)

此計算機使用的演算法

Kahn 演算法 (基於 BFS,1962)

Kahn 演算法是最直觀的拓撲排序方法。在每一步中,它挑選一個入度為零(沒有指向它的邊)的頂點,將其追加到輸出中,並通過減少其每個後續頂點的入度來將其從圖中「移除」。當有多個入度為零的頂點時,可以使用最小堆(得到字典序最小排序)或 FIFO 隊列(得到插入順序)來打破僵局。Kahn 演算法的運行時間為 O(|V| + |E|),且兼具環路偵測功能:如果隊列清空後仍有頂點入度 > 0,則圖中存在環路。

Kahn 演算法 (偽代碼)
Kahn(G):
  Q ← { v ∈ V : indeg(v) = 0 }
  L ← [ ]
   Q 不為空:
    u ← Q.pop()
    L.append(u)
    對於 每條邊 u → v:
      indeg(v) -= 1
      如果 indeg(v) = 0:Q.push(v)
  如果 |L| < |V|:報告環路
  否則:返回 L

DFS 後序遍歷 (Tarjan, 1976)

DFS 演算法執行深度優先搜索,每當一個頂點完成探索(即其所有後續頂點都已被完全探索)時,將其壓入棧中。最後反轉棧即可得到有效的拓撲排序。環路偵測非常自然:遇到一個仍在處理中(標記為 GRAY)的頂點意味著找到了回邊,因此該圖不是 DAG。DFS 後序遍歷的運行時間同樣為 O(|V| + |E|)。

DFS 後序遍歷 (偽代碼)
DFS-Topo(G):
  對於 V 中的每個頂點 u:color[u] ← WHITE
  L ← 空棧
  對於 V 中的每個頂點 u:
    如果 color[u] = WHITE:visit(u)
  返回 reverse(L)

visit(u):
  color[u] ← GRAY
  對於 每條邊 u → v:
    如果 color[v] = GRAY:報告環路
    如果 color[v] = WHITE:visit(v)
  color[u] ← BLACK; L.push(u)

並行執行層級

DAG 的分層視圖將其頂點劃分為不同的級別,使得每條邊都從編號較低的層級指向編號較高的層級。同一層中的頂點相互獨立,因此可以並行執行。層級數量等於最長路徑長度加一 — 這就是 DAG 的關鍵路徑,即在擁有無限並行能力的情況下,完成所有任務所需的最少順序輪次。只要輸入是 DAG,此計算機就會自動生成分層視圖。

環路偵測

如果圖中包含有向環,則無法進行拓撲排序。我們的計算機將報告確切的環路路徑(例如 A → B → C → A)並在視覺化圖表中以紅色突出顯示環路邊。移除環路上的任何一條邊都足以恢復無環性。

輸入格式

邊列表

將每條有向邊寫為 源點 -> 目標點,以逗號或換行符分隔。接受的箭頭變體:->, , =>, -->, :。您也可以連寫邊:A -> B -> CA->BB->C 的簡寫。頂點標籤可以是字母、數字、下劃線、連字符和點。

A -> B, B -> C, A -> C
C -> D
Shirt -> Tie -> Jacket

鄰接表

寫下每個頂點、一個冒號及其直接後續頂點(它指向的頂點)。沒有後續頂點的頂點仍需要佔一行,例如 D:

A: B, C
B: D
C: D
D:

如何使用此計算機

  1. 選擇格式: 通過單選按鈕在邊列表和鄰接表之間切換。
  2. 輸入圖形: 粘貼您的數據或點擊快速範例(穿衣順序、課程先修、構建目標、包含環路的圖形等)。
  3. 選擇演算法: Kahn 字典序以獲得唯一且可復現的順序;插入順序以保留輸入順序;DFS 後序遍歷用於經典深度優先方法;或選擇顯示全部以並排查看所有排序。
  4. 點擊「進行拓撲排序」: 排序結果、環路偵測、分層視圖、關鍵路徑長度、有效排序總數以及交互式圖表將顯示在下方。
  5. 探索: 按下播放鍵觀看每個頂點逐步輸出的過程。入度標記會實時更新。拖拽任何節點可調整佈局。

實際應用

構建系統與編譯器

make、Bazel、Gradle 和 npm 等工具會對其構建目標進行拓撲排序,以便每個目標僅在其所有相依項編譯完成後才進行編譯。相依圖中的環路通常被報告為致命錯誤 — 構建系統無法決定從哪裡開始。

任務調度

項目經理使用 DAG 來捕捉任務相依關係。拓撲排序提供了有效的執行順序,而分層視圖則提供了無限並行下的最少輪次。最長鏈是決定項目工期的關鍵路徑

課程先修規劃

大學課程目錄是一個 DAG:邊代表先修關係。拓撲順序是一個有效的學習計劃,而分層結構則告訴學生在每個學期中哪些課程組可以並行修讀。

電子表格重新計算

當一個單元格發生變化時,電子表格必須按相依順序重新計算每個下游單元格 — 這就是對單元格相依 DAG 進行拓撲排序。循環引用(環路)會被應用程式拒絕。

軟體包管理器與插件加載器

Apt、pip、Homebrew、Maven 和無數插件框架通過對其相依 DAG 進行拓撲排序來解決安裝或加載順序。

符號解析與指令調度

編譯器使用拓撲排序來排列聲明,而 CPU 使用數據相依 DAG 在重排序緩衝區中調度指令,以避免違反數據冒險。

計算拓撲排序的數量

對於一個具有 n 個頂點的 DAG,截然不同的有效拓撲排序數量範圍可以從 1(全序鏈)到 n!(無邊圖)。計算確切數量在一般情況下是 #P-complete 問題,但對於最多 16 個頂點的圖形,此計算機使用位掩碼動態規劃公式進行枚舉:f(S) = Σ f(S ∪ {v}),其中 v ∉ S 且其前驅頂點皆在 S 中。

複雜度與性能

常見問題

什麼是拓撲排序?

有向無環圖的拓撲排序是其頂點的線性排序,使得從 u 到 v 的每條有向邊都讓 u 排在 v 之前。它代表了在尊重相依關係的情況下處理任務的有效順序。

此計算機使用哪種演算法?

計算機同時運行 Kahn 演算法和 DFS 後序遍歷。Kahn 演算法重複移除入度為零的頂點並減少其後續頂點的入度。DFS 後序遍歷執行深度優先搜索並反轉完成順序。兩者的運行時間均為 O(|V| + |E|)。

如果我的圖形有環怎麼辦?

具有有向環的圖沒有拓撲排序。計算機將偵測到環路,在視覺化圖表中以紅色突出顯示,並報告確切的環路路徑,以便您查看應移除哪些邊使圖形變為 DAG。

什麼是字典序最小的拓撲順序?

當存在多個有效的拓撲排序時,在每一步始終挑選字母順序最小且入度為零的頂點,即可獲得字典序最小的排序。此計算機預設的 Kahn 模式會返回此唯一排序,該排序穩定且易於復現。

什麼是分層或級別視圖?

分層視圖根據距任何源點的最長路徑長度對頂點進行分組。同一層中的頂點之間沒有相依關係,因此可以並行執行。層數等於最長相依鏈加一,代表了完成所有任務所需的最少並行輪次。

一個圖形可以有多個有效的拓撲排序嗎?

是的。如果在 Kahn 演算法的任何步驟中有多個入度為零的頂點,則接著可以挑選其中任何一個。此計算機可計算最多 16 個頂點的圖形中截然不同拓撲排序的確切數量。

Kahn 演算法和 DFS 後序遍歷有什麼區別?

Kahn 演算法是自頂向下的:它重複挑選源點(入度 0)並首先輸出它們。DFS 後序遍歷是自底向上的:它先完成匯點並將其前置於順序中。兩者均為 O(|V| + |E|) 並產生有效的拓撲排序,但通常結果不同。Kahn 演算法更容易並行化以及適配字典序;DFS 則更容易與其他基於 DFS 的分析(如強連通分量)相結合。

此工具支持的最大圖形大小是多少?

計算機支持最多 80 個頂點和 800 條邊。計算有效拓撲排序總數的功能限制在 16 個頂點,因為該問題屬於 #P-complete,狀態空間按 2ⁿ 增長。交互式視覺化和演算法動畫可流暢支持至完整限制大小。

延伸閱讀

引用此內容、頁面或工具為:

"拓撲排序計算機" 於 https://MiniWebtool.com/zh-tw/拓撲排序計算機/,來自 MiniWebtool,https://MiniWebtool.com/

由 miniwebtool 團隊製作。更新日期:2026年4月20日

您還可以嘗試我們的 AI數學解題器 GPT,通過自然語言問答解決您的數學問題。

其他相關工具:

進階數學計算:

常用工具:

分數計算機隨機撲克手牌生成器真心話大冒險產生器標準偏差計算機 - 高精度磅轉公斤轉換器最簡分數計算機斜邊計算機相對標準偏差計算機羅馬數字轉換器百分比增加計算機毛利率計算機MAC地址查找比例計算機kg到lbs轉換器圓計算機百分比折扣計算機kpa到psi轉換器圖片分割器AI內容檢測器百分比增長率計算機太陽、月亮與上升星座計算機 🌞🌙✨分數到小數計算機百分比減少計算機質數分解計算機年齡計算機平均值計算機百分比誤差計算機🎮 遊戲靈敏度轉換器商和餘數計算機分數百分比轉換器反向文字迷宮產生器校正鈣計算機隨機撲克牌產生器HEX計算機隨機名稱生成器百分比變化計算機年份天數計算機 - 今天是今年的第幾天影片轉圖片擷取器百分比計算機坡度與傾斜度計算機查找並替換文字SRT時間偏移加價計算機CAGR計算機凱薩密碼工具ANC計算機對數計算機樂透號碼生成器複利計算機調整影片速度定期存款計算機二次公式計算機線性迴歸計算機棒球打擊率計算機OPS計算機克到磅轉換器小數到分數計算機隨機錦標賽對陣生成器積分計算機最小公倍數計算機比率與百分比計算機隨機信用卡生成器畢達哥拉斯定理計算機AI標點符號添加器簡單利息計算機跑步配速計算機MAC地址產生器合併影片我的幸運數字是什麼隨機選擇器文字重複工具隨機餐點產生器因子計算機psi到kpa轉換器多分數計算機小字體生成器 ⁽ᶜᵒᵖʸ ⁿ ᵖᵃˢᵗᵉ⁾組合計算機隨機顏色生成器隨機生日生成器階乘計算機賓果卡生成器二進製計算機音訊分割器厘米到英尺和英寸轉換器PSI 轉 Bar 轉換器圖片打碼工具移除標點符號線上工具隨機字母生成器步數距離計算機橢圓 周長計算機樣本標準差計算機分數簡化最大公因子計算機SRT轉換為TXT工具兩點間距離計算機上壘率計算機文件大小轉換器影片壓縮器弧長計算機歐拉方法計算機方向場斜率場繪圖器二階常微分方程求解器一階常微分方程求解器穩定婚姻問題求解器網路最大流計算機平面圖檢查器漢密爾頓路徑檢查器旅行推銷員問題求解器 (TSP)線性規劃求解器容斥原理計算機遞迴關係求解器鄰接矩陣計算機拓撲排序計算機圖著色計算機邏輯閘模擬器卡諾圖 (K-Map) 求解器布林代數化簡器分拆函數計算機數字根計算機費波那契數檢查器埃及分數計算機莫比烏斯函數計算機哥德巴赫猜想驗證器梅森質數檢查器孿生質數查找器親和數檢查器完全數檢查器模冪運算計算機重複排列計算機效果量計算機相對風險計算機勝算比計算機列聯表計算機費雪精確檢定計算機斯皮爾曼等級相關係數計算機貝塔分布計算機韋布爾分佈計算機指數分佈計算機幾何分佈計算機負二項分布計算機超幾何分布計算機F-Test/F分布計算機貝氏定理計算機特徵多項式計算機矩陣冪計算機喬列斯基分解計算機QR分解計算機矩陣對角化計算機Cramer's Rule Calculator行空間計算機零空間計算機向量夾角計算機單位向量計算機向量大小計算機向量外積計算機向量點積計算機矩陣乘法計算機逆矩陣計算機RREF計算機列最簡階梯形牛頓迭代法計算機雅可比矩陣計算機曲面積分計算機線積分計算機旋度計算機散度計算機梯度計算機多變量優化計算機微積分相關變化率求解器瞬時變化率計算機平均變化率計算機無限級數求和計算機級數收斂判定計算機冪級數計算機麥克勞林級數計算機洛必達法則計算機廣義積分計算機辛普森法則計算機梯形法則計算機黎曼和計算機參數曲線繪圖器旋轉體表面積計算機旋轉體體積計算機座標幾何距離計算機海倫公式計算機圓的切線計算機角平分線計算機內切圓計算機三角形外接圓計算機大圓距離計算機3D距離計算機環面計算機圓台計算機不規則多邊形面積計算機正多邊形計算機圓錐曲線識別器雙曲線計算機拋物線計算機二項式定理展開計算機帕斯卡三角形產生器乘積符號計算機 (Pi 記號)西格瑪求和計算機有理根定理計算機笛卡爾符號法則計算機平行線和垂直線計算機直線方程式計算機標準形式轉斜截式轉換器點斜式計算機非線性方程組求解器有理方程式求解器字母方程式求解器三角方程式求解器指數方程式求解器對數方程式求解器四次方程式計算機三次方程求解器估算計算機數字轉分數轉換器跳數產生器單位費率計算機上取整和下取整計算機絕對值計算機數列模式查找器位值圖產生器運算順序計算機PEMDAS直式加減法計算機長乘法計算機乘法表產生器🎮 遊戲貨幣換算器🎲 掉落機率計算機🎰 抽卡保底計算機⚔️ DPS計算機❄️ 雪天計算機🚚 搬家費用估算器🔍 抄襲檢測器📷 OCR / 圖片文字辨識📈 折線圖製作工具🥧 圓餅圖製作工具📊 長條圖製作工具🔊 音調產生器🖱️ 點擊計數器線上記事本⬛ 寬高比計算機🌍 碳足跡計算機👙 胸罩尺碼計算機輪胎尺寸計算機燃油費用計算機💧 露點計算機🌡️ 體感溫度計算機🌬️ 風寒指數計算機⏰ 線上鬧鐘⏰ 打卡計算機📅 日期差計算機🕐 軍事時間轉換器⏱️ 小時計算機⏱️ 線上碼錶⏱️ 倒數計時器🌐 時區轉換器地毯計算機擋土牆計算機HVAC容量計算機隔熱材料計算機鋪路石計算機鋼筋計算機木材計算機平方英尺計算機交叉相乘計算機五數概括計算機百分位數計算機正態分布計算機p值計算機比率計算機配方法計算機四捨五入計算機長除法計算機科學計算機番茄鐘學習計時器有效數字計算機考試成績計算機加權成績計算機期末成績計算機成績計算機諧振頻率計算機阻抗計算機分貝 (dB) 計算機功率因數計算機RC時間常數計算機變壓器計算機線規計算機555定時器計算機電容器計算機並聯電阻計算機分壓器計算機LED電阻計算機莫耳/克/粒子轉換器滴定計算機沸點計算機經驗式計算機百分產率計算機化學計量計算機化學方程式平衡器稀釋計算機馬力計算機扭矩計算機自由落體計算機理想氣體狀態方程計算機壓力計算機密度計算機功和功率計算機位能計算機動能計算機拋體運動計算機動量計算機速度計算機加速度計算機力計算機網紅行銷ROI計算機ROAS計算機CTR計算機社交媒體用戶名檢查器社群媒體發文時間優化工具社群媒體ROI計算機Facebook廣告費用計算機YouTube Shorts 收益計算機Twitch收益計算機YouTube觀看時間計算機Twitter/X 時間戳轉換器YouTube頻道統計TikTok收益計算機社群媒體圖片尺寸指南Instagram字體生成器Twitter/X 字元計數機YouTube留言抽選器YouTube標籤提取器YouTube縮圖下載器YouTube收益估算器隨機RPG角色生成器