【C语言教程】算法积累图的遍历邻接表简单路径详解

零 C语言教程评论120字数 891阅读2分58秒阅读模式

所需工具:

C++

聪明的大脑文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

勤劳的双手文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

 文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

注意:本站只提供教程,不提供任何成品+工具+软件链接,仅限用于学习和研究,禁止商业用途,未经允许禁止转载/分享等文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

 文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

教程如下

题目

假设图用邻接表表示,设计一个算法,输出从顶点Vi到Vj的所有简单路径文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

关键字: 图,邻接表,简单路径文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

思路:

Vi=u,Vj=v文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

本题采用基于递归的深度优先遍历算法,从结点u出发,递归深度优先遍历图中各个结点,若访问到结点v,则输出该搜索路径上的结点。文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

为此,设置:一个path数组来存放路径上的结点(初始为空),d表示路径长度(初始为-1)。文章源自灵鲨社区-https://www.0s52.com/bcjc/cyyjc/12345.html

查找从顶点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

代码:

[php]
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;//恢复环境,使该顶点可重新使用
}
[/php]

 

 

零
  • 转载请务必保留本文链接:https://www.0s52.com/bcjc/cyyjc/12345.html
    本社区资源仅供用于学习和交流,请勿用于商业用途
    未经允许不得进行转载/复制/分享

发表评论