對一個有向無環(huán)圖(Directed Acyclic Graph, DAG)G進(jìn)行拓?fù)渑判?,將G中所有頂點(diǎn)排成線性序列,使得圖中任意一對頂點(diǎn)u、v,若邊(u,v)∈E(G),則在線性序列中u出現(xiàn)在v之前。

隊列Queue--拓?fù)渑判蚴纠?/div>
拓?fù)渑判虻姆椒ǎ?/h4>
1. 在有向圖G中任選一個沒有前驅(qū)(即入度為0)的頂點(diǎn)并輸出它;
2. 從G中刪除該頂點(diǎn),并且刪除去從該頂點(diǎn)出發(fā)的全部有向邊;
3. 重復(fù)上述兩步,直到剩余的網(wǎng)絡(luò)中不再存在有前驅(qū)的頂點(diǎn)為止。

有向無環(huán)圖 demo
Python Demo:
# !/usr/bin/env python
# -- coding: utf-8 --
# @Time : 2017/7/10 11:46
# @Author : Albert·Sun
# @Version : 0.10α
# @Description: (1).用數(shù)組grap存放圖G的連接關(guān)系,grap[i][j]:頂點(diǎn)j指向頂點(diǎn)i,即邊E(j->i),此處邊權(quán)簡化為1; (2).Pyhton中的List結(jié)構(gòu)模擬Queue
def topo(graph):
indegree = []
for i in range(len(graph)):
if sum(graph[i]) is 0:
indegree.append(i)
while len(indegree) > 0:
cur = indegree.pop(0)
print cur+1,
for i in range(len(graph)):
graph[i][cur] = 0
graph[cur][cur] = -1
# print graph
for i in range(len(graph)):
if graph[i][i] is not -1 and graph[i].count(1) is 0:
if indegree.count(i) <= 0:
indegree.append(i)
# print indegree
if __name__ == "__main__":
grap = [[0, 0, 0, 0, 0, 1],
[1, 0, 0, 0, 0, 1],
[1, 1, 0, 0, 0, 1],
[1, 0, 1, 0, 0, 0],
[1, 1, 0, 1, 0, 0],
[0, 0, 0, 0, 0, 0],
]
topo(grap)
輸出:6 -> 1 -> 2 -> 3 -> 4 -> 5
注:
拓?fù)渑判虻谋举|(zhì)是不斷地輸出入度為0的點(diǎn);
該算法可用于判斷圖中是否存在環(huán)。
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 第一章 緒論 什么是數(shù)據(jù)結(jié)構(gòu)? 數(shù)據(jù)結(jié)構(gòu)的定義:數(shù)據(jù)結(jié)構(gòu)是相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合。 第二章...
- https://zh.visualgo.net/graphds 淺談圖形結(jié)構(gòu)https://zh.visualgo...
- 因?yàn)橹熬蛷?fù)習(xí)完數(shù)據(jù)結(jié)構(gòu)了,所以為了保持記憶,整理了一份復(fù)習(xí)綱要,復(fù)習(xí)的時候可以看著綱要想具體內(nèi)容。 樹 樹的基本...
- 我無聊的時候會刷朋友圈。昨晚刷朋友圈刷出來一條爆炸性的消息。室友在和一個我們玩的很好的女生表白。這不是重點(diǎn),重點(diǎn)是...