C语言算法积累图的遍历邻接表简单路径

 更新时间:2022年06月06日 17:06:56   作者:aprilzj123  
这篇文章主要为大家介绍了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语言算法积累图的遍历邻接表简单路径的详细内容,更多关于C语言图遍历邻接表简单路径的资料请关注脚本之家其它相关文章!

相关文章

  • C语言如何输出中文

    C语言如何输出中文

    这篇文章主要介绍了C语言如何输出中文问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • 数组中求第K大数的实现方法

    数组中求第K大数的实现方法

    本篇文章是对数组中求第K大数的实现方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 一文带你了解Qt中槽的使用

    一文带你了解Qt中槽的使用

    这篇文章主要为大家详细介绍了Qt中槽的使用教程,文中的示例代码讲解详细,对我们学习Qt有一定的帮助,感兴趣的小伙伴可以跟随小编一起学习一下
    2022-12-12
  • C语言实现制作通讯录(新手推荐)

    C语言实现制作通讯录(新手推荐)

    本文推荐给C语言学习到结构体的新手们,供其练习。这篇文章主要是利用C语言制作一个简单的通讯录功能,感兴趣的小伙伴可以跟随小编一起了解一下
    2022-09-09
  • C/C++使用socket实现判断ip是否能连通

    C/C++使用socket实现判断ip是否能连通

    这篇文章主要为大家详细介绍了C/C++如何使用socket实现判断ip是否能连通,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以了解一下
    2023-07-07
  • C语言实现导航功能

    C语言实现导航功能

    这篇文章主要为大家详细介绍了C语言实现导航功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 枚举和宏的区别详细解析

    枚举和宏的区别详细解析

    枚举常量具有类型,但宏没有类型,枚举变量具有与普通变量相同的诸如作用域、值等性质,但宏没有,宏不是语言的一部分,它是一种预处理替换符
    2013-09-09
  • C++内存对齐的实现

    C++内存对齐的实现

    本文主要介绍了C++内存对齐的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • C语言超全面define预处理指令的使用说明

    C语言超全面define预处理指令的使用说明

    C语言里可以用#define定义一个标识符来表示一个常量。特点是:定义的标识符不占内存,只是一个临时的符号,预编译后这个符号就不存在了,也不做类型定义。预编译又叫预处理
    2022-04-04
  • c语言中enum类型的用法案例讲解

    c语言中enum类型的用法案例讲解

    这篇文章主要介绍了c语言中enum类型的用法案例讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是本文的详细内容,需要的朋友可以参考下
    2021-07-07

最新评论