日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python 拓扑排序 dfs bfs_拓扑排序的DFS和BFS

發布時間:2025/4/5 python 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 拓扑排序 dfs bfs_拓扑排序的DFS和BFS 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

博主以前有一個疑問,DFS和BFS各自的適用范圍是?我想你今天看了這篇文章之后會有一個判斷!

BFS

數據結構與算法分析:c語言描述(p217)

已經存在一個Indgree入度數組(indgree[v]={(u,v)的數目})

以及一個鄰接矩陣,求一個拓撲排序

提示:圖中出現環就會拓撲失敗

代碼風格被我改為了C++

void TopSort(vector> G){

//圖中所有的點都要被遍歷到,每次取出一個點,共執行NumVertex次

for(int counter=0;counter

int v=findVertexIndgreeZero(G);//尋找入度為0的點

if(!v){

cout<

return;

}

TopNum[v]=counter;//第counter+1個被遍歷到的

for(int i;i

if(G[v][i])

indgree[i]--;

}

}

}

用一句話來概括這個算法就是依次尋找出入度為0的點,然后將其所通的所有點入度都減1。循環直至結束或者報錯(有環)。

上面這個算法存在優化的余地,findVertexIndgreeZero()的復雜度為O(n),執行n次為O(N2)次,用一個隊列會大大縮減復雜度

void TopSort(vector> G){

int counter=0;

queue q;

for(int i=0;i

if(indgree[i]==0);

q.push(i);

}

while(!q.empty()){

int u=q.top();q.pop();

TopNum[u]=counter++;

for(int i=0;i

if(G[u][i]){

if(--indgree[i]==0)

q.push(i);

}

}

}

if(counter!=G.size())

cout<

}

這個結果很有趣,我們可以不嚴謹地總結一下“拓撲排序就是在找入度0點+更新入度”。

題外話

另外TopNum[i]保存了遍歷的順序。那么能不能TopNum[counter]=i,這樣呢。。也可以。因為i和counter肯定是一一映射的關系。如果學習過數據庫,那么你就可以說:誰來做主鍵都可以。

DFS

劉汝佳 算法競賽入門經典第二版

P167

假設有n個變量,m個二元組(u,v),分別表示u< v。那么尋找一個不等式,包含所有的變量。類似于a< b,b< c ,則輸出a< b< c;

我們可以把二元組小于關系看作邊關系。這一轉換其實很自然。

然后,尋找一個不等式,其實就是在尋找一個拓撲順序。那么,這個問題其實就是一個拓撲排序,完全可以用BFS完成

但是還有另外一種比較有趣的解法,就是使用dfs。

我們首先定義一個函數

bool dfs(int u);//u代表當前點,返回點u之后是否存在一個拓撲路線

有了這個定義就不難繼續做下去了,我們再想到:當前點u若是想能夠返回true,那么它所能到達(u->v)的所有點也應該都能。

那么,失敗的具體條件是什么?就是成環!

只要之后遍歷到的點和之前的點u有關系(v->u),那么就說明成環!返回false。

那么,代碼應該是:

int vector> G

int c[maxn];

int TopNum[maxn];

int t;

bool dfs(int u){

c[u]=-1;

for(int i=0;i

if(G[u][i]){

if(c[i]==-1){//大水沖了龍王廟,這個i點在之前已經被遍歷到了,成環!

return false;

}

if(!c[i]&&!dfs(i)) return false;

}

//經過了檢驗

c[u]=1;

TopNum[--t]=u;

return true;

}

bool topsort(){

int t=n;

memset(c,0.sizeof(c));

for(int i=0;i

if(!c[u])

if(!dfs(u))

return false;

return true;

}

總結

以上是生活随笔為你收集整理的python 拓扑排序 dfs bfs_拓扑排序的DFS和BFS的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 一级性生活黄色片 | 丁香一区二区 | 你懂的亚洲 | 国产在线国偷精品免费看 | 亚洲福利一区二区 | 国产av自拍一区 | 就爱av | 男生和女生差差的视频 | 日韩中文字幕免费 | 亚洲一级在线 | 欧美激情视频网址 | 免费黄色在线网站 | 麻豆成人精品国产免费 | 狂野欧美性猛交blacked | 亚洲小说区图片区 | 日韩精品不卡 | 国产性色av | 手机av网| 欧美一区三区二区在线观看 | 91视频一区| 884aa四虎影成人精品一区 | 在线小视频 | 丁香婷婷久久久综合精品国产 | 中文字字幕在线中文乱码电影 | 日本精品一区二区视频 | 久久99精品久久久久婷婷 | 强伦轩人妻一区二区电影 | 麻豆视频在线看 | 日韩一区免费观看 | 亚洲av无一区二区三区怡春院 | 免费黄色美女网站 | 爱情岛论坛自拍亚洲品质极速最新章 | 9色在线| 久久视频免费观看 | a级片免费看 | 久久精品久| 欧美真人性野外做爰 | 欧美日韩中文字幕在线播放 | 亚洲视频久久 | 男人在线天堂 | 国产一在线 | 小镇姑娘国语版在线观看免费 | 国产成人在线视频观看 | 庆余年三 | 这里精品| 日韩精品一区二区在线 | 贝利弗山的秘密1985版免费观看 | 成年人福利 | 毛片www | 波多野吉衣av无码 | 好吊色在线视频 | 亚洲日本视频在线观看 | 国产精品第三页 | 欧美brazzers| 国产伦精品一区二区三区四区免费 | 另类老妇性bbwbbw图片 | 黄色一级小视频 | 国产美女免费视频 | 欧美日韩大片 | 欧美一区二区三区免 | 国产乱乱 | 日韩二区三区 | 白浆影院| 色汉综合| 国产精品视频第一页 | 亚洲国产精品久久久久爰性色 | 3d动漫精品啪啪一区二区下载 | 黄色成人在线 | 亚洲欧美日韩国产一区 | 国产欧美a| 91人妻一区二区三区蜜臀 | 丝袜美腿亚洲一区二区图片 | 亚洲成人高清在线观看 | 亚洲国产欧美精品 | 91日批 | 日韩www.| 国产理论一区 | 亚洲调教欧美在线 | 久久久久色 | 亚洲瘦老头同性xxxxx | 国产精品久久久久免费 | 91亚洲精品久久久久久久久久久久 | 天天天av| 欧美人妖乱大交 | 一级黄色视 | 久久免费黄色 | 国产一区二区三区黄 | 亚洲色图第1页 | 激情九月婷婷 | 日本成人黄色 | 亚洲无码精品国产 | 爱视频福利网 | 浪漫樱花在线观看高清动漫 | 日韩精品在线播放 | 亚州a级片| 中文有码一区 | 麻豆成人网| 免费中文字幕视频 | 国产xxxx18 |