中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言怎么遍歷鄰接表簡單路徑

發布時間:2022-06-07 09:23:47 來源:億速云 閱讀:217 作者:zzz 欄目:開發技術

這篇“C語言怎么遍歷鄰接表簡單路徑”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“C語言怎么遍歷鄰接表簡單路徑”文章吧。

題目

假設圖用鄰接表表示,設計一個算法,輸出從頂點Vi到Vj的所有簡單路徑

關鍵字: 圖,鄰接表,簡單路徑

思路:

Vi=u,Vj=v

本題采用基于遞歸的深度優先遍歷算法,從結點u出發,遞歸深度優先遍歷圖中各個結點,若訪問到結點v,則輸出該搜索路徑上的結點。

為此,設置:一個path數組來存放路徑上的結點(初始為空),d表示路徑長度(初始為-1)。

查找從頂點u到v 的簡單路徑過程說明如下

(假設查找函數名為FindPath()):

1)FindPath(G,u,v,path,d):

d++;path[d]=u;

若找到u的未訪問過的相鄰結點u1,則繼續下去,

否則置visited[u]=0并返回。

2)FindPath(G,u1,v,path,d):

d++;path[d]=u1;

若找到u1的未訪問過的相鄰結點u2,則繼續下去,

否則置visited[u1]=0并返回。

3)以此類推,繼續上述遞歸過程,直到ui=v,輸出path

代碼:

void FindPath (AGraph *G,int u,int v,int path[],int d){
      int w;//w是每一次遍歷中,當前結點的下一個鄰接頂點的代表變量
      ArcNode*p;
      d++;//路徑長度增加1
      path[d]=u;//將當期頂點添加到路徑中
      visited[u]=1;//設置已訪問結點
      if(u==v)//找到一條路徑則輸出
           print(path[]);//輸出路徑上的結點
      p=G->adjlist[u].firstarc;//p指向u的第一個相鄰點
      while(p!=NULL){     //遍歷u的所有相鄰點
        w=p->adjvex;//w為下一個鄰接頂點
        if(visited[w]==0)//若頂點w未訪問,遞歸訪問它
           FindPath(G,w,V,path,d);
        p=p->nextarc;//p指向u的下一個相鄰點
      }
      visited[u]=0;//恢復環境,使該頂點可重新使用
  }

以上就是關于“C語言怎么遍歷鄰接表簡單路徑”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙口市| 布尔津县| 宽甸| 女性| 黎城县| 象州县| 陈巴尔虎旗| 呼伦贝尔市| 都安| 胶州市| 凉山| 庆安县| 桑植县| 五大连池市| 灵川县| 凤山市| 绍兴市| 隆回县| 宾川县| 乌鲁木齐县| 南通市| 夏邑县| 福建省| 长泰县| 淮安市| 阜南县| 清水河县| 盘锦市| 大港区| 乡城县| 黄龙县| 梅州市| 沙河市| 澄迈县| 嘉鱼县| 信丰县| 托里县| 兴国县| 清远市| 黄大仙区| 清水河县|