亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++深度優先搜索的實現方法

2020-01-26 15:24:23
字體:
來源:轉載
供稿:網友

本文實例講述了圖的遍歷中深度優先搜索的C++實現方法,是一種非常重要的算法,具體實現方法如下:

首先,圖的遍歷是指從圖中的某一個頂點出發,按照某種搜索方法沿著圖中的邊對圖中的所有頂點訪問一次且僅訪問一次。注意到樹是一種特殊的圖,所以樹的遍歷實際上也可以看作是一種特殊的圖的遍歷。圖的遍歷主要有兩種算法:廣度優先搜索(Breadth-First-Search)和深度優先搜索(Depth-First-Search)。

一、深度優先搜索(DFS)的算法思想

深度優先搜索算法所遵循的搜索策略是盡可能“深”地搜索一個圖。它的基本思想就是:首先訪問圖中某一起始頂點v,然后由v出發,訪問與v鄰接且未被訪問的任一頂點w1,再訪問與w1鄰接且未被訪問的任一頂點w2,……重復上述過程。當不能再繼續向下訪問時,依次退回到最近被訪問的頂點,若它還有鄰接頂點未被訪問過,則從該點開始繼續上述搜索過程,直到圖中所有頂點均被訪問過為止。

如上圖所示,從頂點2開始深度優先遍歷圖,結果為:2,0,1,3。

二、DFS算法實現

和廣度優先搜索一樣,為了防止頂點被多次訪問,需要使用一個訪問標記數組visited[]來標記頂點是否已經被訪問過。

這里使用鄰接表表示圖。對于一個有向圖,假設從給定頂點可以訪問到圖的所有其他頂點,則DFS遞歸算法的C++代碼實現:

/*************************************************************************   > File Name: DFS.cpp   > Author: SongLee  ************************************************************************/ #include<iostream> #include<list> using namespace std;  /* 圖 */ class Graph {   int V;                // 頂點數   list<int> *adj;           // 鄰接表   void DFSUtil(int v, bool visited[]); // 從頂點v深度優先遍歷 public:   Graph(int V);            // 構造函數   void addEdge(int v, int w);     // 向圖中添加邊   void DFS(int v);           // 從v開始深度優先遍歷圖 };  /* 構造函數 */ Graph::Graph(int V) {   this->V = V;   adj = new list<int>[V]; }  /* 添加邊,構造鄰接表 */ void Graph::addEdge(int v, int w) {   adj[v].push_back(w);         // 將w添加到v的鏈表 }  /* 從v開始深度優先遍歷 */ void Graph::DFSUtil(int v, bool visited[]) {   // 訪問頂點v并輸出   visited[v] = true;   cout << v << " ";    list<int>::iterator i;    for(i=adj[v].begin(); i!=adj[v].end(); ++i)     if(!visited[*i])       // 若鄰接點尚未訪問       DFSUtil(*i, visited);   // 遞歸 }  /* 對圖進行深度優先遍歷,調用遞歸函數DFSUtil() */ void Graph::DFS(int v) {   bool *visited = new bool[V];   for(int i=0; i<V; ++i)     visited[i] = false;    // 假設從給定頂點v可以到達圖的所有頂點   DFSUtil(v, visited); }  /* 測試 */ int main() {   Graph g(4);   g.addEdge(0, 1);   g.addEdge(0, 2);   g.addEdge(1, 2);   g.addEdge(2, 0);   g.addEdge(2, 3);   g.addEdge(3, 3);    cout << "Depth First Traversal (starting from vertex 2) /n";   g.DFS(2);   cout << endl;      return 0; }

上面的代碼是假設從給定頂點可以訪問到圖的所有其他頂點。如果沒有這個假設,為了對圖作一個完整的深度優先遍歷,我們需要對每個頂點調用DFSUtil()。當然那之前需要先檢查頂點是否已經訪問過。所以我們只需要修改DFS()函數部分:

void Graph::DFS() {   bool *visited = new bool[V];   for(int i=0; i<V; ++i)     visited[i] = false;      // 對每個頂點調用DFSUtil(),從0開始   for(int i=0; i<V; ++i)     if(!visited[i])       DFSUtil(i, visited); } 

對于無向圖的深度優先搜索,只是鄰接表不一樣,其他的都是一樣的。我們只需要修改addEdge(v, w)函數:

void Graph::addEdge(int v, int w) {   adj[v].push_back(w);     // 將w加到v的list   adj[w].push_back(v); } 

注意:圖的鄰接矩陣表示是唯一的,但對于鄰接表來說,如果邊的輸入次序不同,生成的鄰接表也不同。因此,對于同一個圖,基于鄰接矩陣的遍歷所得到的DFS序列和BFS序列是唯一的,基于鄰接表的遍歷所得到的DFS序列和BFS序列是不唯一的。

三、DFS算法性能分析

1 . 空間復雜度

DFS算法是一個遞歸算法,需要借助一個遞歸工作棧,故它的空間復雜度為O(|V|)。

2 . 時間復雜度

當以鄰接表存儲時,時間復雜度為O(|V|+|E|)。

當以鄰接矩陣存儲時,時間復雜度為O(|V|^2)。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人写真视频福利网| 国产欧美一区二区三区久久| 欧美精品一区二区免费| 亚洲激情视频在线观看| 精品无人区太爽高潮在线播放| 亚洲最大av网| 欧美日韩在线免费观看| 欧美黑人国产人伦爽爽爽| 欧美老女人在线视频| 亚洲理论在线a中文字幕| 精品毛片网大全| 久久久久久久97| 中文字幕精品影院| 日韩三级成人av网| 日韩精品久久久久久久玫瑰园| 欧美日韩久久久久| 91性高湖久久久久久久久_久久99| 欧美高清在线播放| 国产成人精品免高潮费视频| 成人激情黄色网| 色婷婷av一区二区三区久久| 日韩福利伦理影院免费| 中文字幕日韩av综合精品| 欧美日韩国产在线看| 一区二区在线视频| 亚洲毛片在线免费观看| 亚洲精品一区中文| 国产精品www色诱视频| 亚洲国产日韩欧美在线99| 日韩在线观看电影| 国产精品久久久久77777| 国产精品h片在线播放| 亚洲日本成人网| 欧美国产亚洲视频| 欧美成人高清视频| 色婷婷综合久久久久中文字幕1| 欧美一级淫片videoshd| 久久久久久高潮国产精品视| 欧美日韩精品在线视频| 亚洲第一视频网| 8x海外华人永久免费日韩内陆视频| 中文字幕亚洲在线| …久久精品99久久香蕉国产| 欧美黑人又粗大| 4444欧美成人kkkk| 久久综合久久美利坚合众国| 亚洲三级 欧美三级| 亚洲精品之草原avav久久| 丁香五六月婷婷久久激情| 一区二区在线视频| 国产在线观看精品一区二区三区| 亚洲国产婷婷香蕉久久久久久| 亚洲综合日韩中文字幕v在线| 欧美性极品xxxx做受| 欧美成人中文字幕在线| 国产一区二区三区在线播放免费观看| 日韩欧美在线观看| 国产精品久久在线观看| 日韩av日韩在线观看| 久久久久久久久中文字幕| 亚洲色图校园春色| 国产精品日韩久久久久| 欧美极品美女电影一区| 久久久人成影片一区二区三区| 欧美激情视频在线免费观看 欧美视频免费一| 国产亚洲免费的视频看| 日韩黄色av网站| 国产精品在线看| 国产91久久婷婷一区二区| 在线观看精品自拍私拍| 日韩成人在线电影网| 精品久久久一区二区| 国产精品视频网| 日韩精品视频免费在线观看| 视频在线一区二区| 久久久久久综合网天天| 久久国产精品影视| 成人激情在线播放| 色悠悠久久88| 91精品久久久久久久久久久| 亚洲欧美福利视频| 亚洲欧洲日产国码av系列天堂| 欧美电影免费观看大全| 欧美华人在线视频| 久久天天躁狠狠躁夜夜躁2014| 欧美一级电影在线| 2020欧美日韩在线视频| 韩国精品久久久999| 中文字幕亚洲图片| 亚洲激情视频在线| 免费成人高清视频| 久久久久中文字幕2018| 亚洲黄色有码视频| 久久久久久久电影一区| 欧美亚洲国产成人精品| 久久久久久久久久国产精品| 欧美高清一级大片| 国产精品久久久久av免费| 伊人精品在线观看| 亚洲美女福利视频网站| 亚洲乱码国产乱码精品精| 成人性生交xxxxx网站| 日本精品一区二区三区在线播放视频| 久久69精品久久久久久久电影好| 日韩欧美大尺度| 国内精品久久影院| 国产精品成人品| 伊人久久大香线蕉av一区二区| 色老头一区二区三区在线观看| 在线视频欧美性高潮| 国内精品久久久久久| 亚洲一区二区三区乱码aⅴ| 亚洲日韩中文字幕在线播放| 中文字幕无线精品亚洲乱码一区| 欧美床上激情在线观看| 91久久精品国产91久久| 欧美精品中文字幕一区| 在线观看视频99| 亚洲精品国产拍免费91在线| 国产精品黄视频| 国产精品中文久久久久久久| 亚洲无线码在线一区观看| 九九九久久久久久| 久久视频免费在线播放| 国产精品第100页| 91免费视频网站| 日韩一区二区三区在线播放| 国产亚洲精品高潮| 在线精品高清中文字幕| 日韩在线观看精品| 亚洲免费影视第一页| 亚洲一品av免费观看| 国产视频亚洲精品| 欧洲亚洲免费视频| 欧美电影免费观看网站| 精品亚洲男同gayvideo网站| 91高清免费在线观看| 欧美一级在线播放| 亚洲电影免费观看高清完整版在线观看| 92版电视剧仙鹤神针在线观看| 黑人巨大精品欧美一区二区一视频| 国产精品高精视频免费| 中文字幕在线亚洲| 欧美精品第一页在线播放| 国产精品嫩草影院一区二区| 亚洲国产欧美精品| 国产日韩欧美视频| 亚洲激情视频在线观看| 一区二区在线视频| 亚洲毛片在线免费观看| 韩国日本不卡在线| 成人午夜黄色影院| 午夜精品三级视频福利| 日韩精品中文字幕视频在线| 午夜精品免费视频| 91国语精品自产拍在线观看性色| 欧美性猛交xxxx富婆弯腰| 激情av一区二区| 永久免费毛片在线播放不卡| 久久久久久中文| 日韩在线视频一区| 亚洲国产高清自拍| 久久成人亚洲精品| 国产精品视频在线播放|