写在最前的三点:

1、所谓图的遍历就是按照某种次序访问图的每一顶点一次仅且一次。

2、实现bfs和dfs都需要解决的一个问题就是如何存储图。一般有两种方法:邻接矩阵和邻接表。这里为简单起

见,均采用邻接矩阵存储,说白了也就是二维数组。

3、本文章的小测试部分的测试实例是下图:

一、深度优先搜索遍历

1、从顶点v出发深度遍历图G的算法

① 访问v

② 依次从顶点v未被访问的邻接点出发深度遍历。

2、一点心得:dfs算法最大特色就在于其递归特性,使得算法代码简洁。但也由于递归使得算法难以理解,原因

在于递归使得初学者难以把握程序运行到何处了!一点建议就是先学好递归,把握函数调用是的种种。

3、算法代码:

[cpp] view plain copy    
  1. #include
  2. using namespace std;
  3. int a[11][11];
  4. bool visited[11];
  5. void store_graph()  //邻接矩阵存储图
  6. {
  7. int i,j;
  8. for(i=1;i<=10;i++)
  9. for(j=1;j<=10;j++)
  10. cin>>a[i][j];
  11. }
  12. void dfs_graph()    //深度遍历图
  13. {
  14. void dfs(int v);
  15. memset(visited,false,sizeof(visited));
  16. for(int i=1;i<=10;i++)  //遍历每个顶点是为了防止图不连通时无法访问每个顶点
  17. if(visited[i]==false)
  18. dfs(i);
  19. }
  20. void dfs(int v)  //深度遍历顶点
  21. {
  22. int Adj(int x);
  23. cout<<v<<" ";  //访问顶点v
  24. visited[v]=true;
  25. int adj=Adj(v);
  26. while(adj!=0)
  27. {
  28. if(visited[adj]==false)
  29. dfs(adj);      //递归调用是实现深度遍历的关键所在
  30. adj=Adj(v);
  31. }
  32. }
  33. int Adj(int x)   //求邻接点
  34. {
  35. for(int i=1;i<=10;i++)
  36. if(a[x][i]==1 && visited[i]==false)
  37. return i;
  38. return 0;
  39. }
  40. int main()
  41. {
  42. cout<<"初始化图:"<<endl;
  43. store_graph();
  44. cout<<"dfs遍历结果:"<<endl;
  45. dfs_graph();
  46. return 0;
  47. }

4、小测试

二、广度优先搜索遍历

1、从顶点v出发遍历图G的算法买描述如下:

①访问v

②假设最近一层的访问顶点依次为vi1,vi2,vi3...vik,则依次访问vi1,vi2,vi3...vik的未被访问的邻接点

③重复②知道没有未被访问的邻接点为止

2、一点心得:bfs算法其实就是一种层次遍历算法。从算法描述可以看到该算法要用到队列这一数据结构。我这

里用STL中的实现。该算法由于不是递归算法,所以程序流程是清晰的。

3、算法代码:

[cpp] view plain copy    
  1. #include
  2. #include
  3. using namespace std;
  4. int a[11][11];
  5. bool visited[11];
  6. void store_graph()
  7. {
  8. for(int i=1;i<=10;i++)
  9. for(int j=1;j<=10;j++)
  10. cin>>a[i][j];
  11. }
  12. void bfs_graph()
  13. {
  14. void bfs(int v);
  15. memset(visited,false,sizeof(visited));
  16. for(int i=1;i<=10;i++)
  17. if(visited[i]==false)
  18. bfs(i);
  19. }
  20. void bfs(int v)
  21. {
  22. int Adj(int x);
  23. queue<<span
    class="datatypes" style="margin: 0px; padding: 0px; border: none;
    color: rgb(46, 139, 87); background-color: inherit; font-weight:
    bold;">int> myqueue;
  24. int adj,temp;
  25. cout<<v<<" ";
  26. visited[v]=true;
  27. myqueue.push(v);
  28. while(!myqueue.empty())    //队列非空表示还有顶点未遍历到
  29. {
  30. temp=myqueue.front();  //获得队列头元素
  31. myqueue.pop();         //头元素出对
  32. adj=Adj(temp);
  33. while(adj!=0)
  34. {
  35. if(visited[adj]==false)
  36. {
  37. cout<<adj<<" ";
  38. visited[adj]=true;
  39. myqueue.push(adj);   //进对
  40. }
  41. adj=Adj(temp);
  42. }
  43. }
  44. }
  45. int Adj(int x)
  46. {
  47. for(int i=1;i<=10;i++)
  48. if(a[x][i]==1 && visited[i]==false)
  49. return i;
  50. return 0;
  51. }
  52. int main()
  53. {
  54. cout<<"初始化图:"<<endl;
  55. store_graph();
  56. cout<<"bfs遍历结果:"<<endl;
  57. bfs_graph();
  58. return 0;
  59. }

4、小测试:

图论中DFS与BFS的区别、用法、详解?的更多相关文章

  1. 图论中DFS与BFS的区别、用法、详解…

    DFS与BFS的区别.用法.详解? 写在最前的三点: 1.所谓图的遍历就是按照某种次序访问图的每一顶点一次仅且一次. 2.实现bfs和dfs都需要解决的一个问题就是如何存储图.一般有两种方法:邻接矩阵 ...

  2. CSS中伪类及伪元素用法详解

    CSS中伪类及伪元素用法详解   伪类的分类及作用: 注:该表引自W3School教程 伪元素的分类及作用: 接下来让博主通过一些生动的实例(之前的作业或小作品)来说明几种常用伪类的用法和效果,其他的 ...

  3. Python中生成器和yield语句的用法详解

    Python中生成器和yield语句的用法详解 在开始课程之前,我要求学生们填写一份调查表,这个调查表反映了它们对Python中一些概念的理解情况.一些话题("if/else控制流" ...

  4. SVN组成中trunk,branches and tags功能用法详解

    SVN组成中trunk,branches and tags功能用法详解  我相信初学开发在SVN作为版本管理时,都估计没可能考虑到如何灵活的运用SVN来管理开发代码的版本,下面我就摘录一篇文章来简单说 ...

  5. Javascript中call和apply的区别与详解

    在js中call和apply它们的作用都是将函数绑定到另外一个对象上去运行,两者仅在定义参数方式有所区别,下面我来给大家介绍一下call和apply用法: 在web前端开发过程中,我们经常需要改变th ...

  6. Python3 中 configparser 模块解析配置的用法详解

    configparser 简介 configparser 是 Pyhton 标准库中用来解析配置文件的模块,并且内置方法和字典非常接近.Python2.x 中名为 ConfigParser,3.x 已 ...

  7. oracle中的exists 和not exists 用法详解

    有两个简单例子,以说明 “exists”和“in”的效率问题 1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ; ...

  8. oracle中的exists 和not exists 用法详解(转)

    有两个简单例子,以说明 “exists”和“in”的效率问题 1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ; ...

  9. 转:Android中的Handler的机制与用法详解

    注:Message类的用法: message的几个参数都可以携带数据,其中arg1与arg2可以携带int类型,what是用户自定义的int型,这样接受者可以了解这个消息的信息. 说明:使用Messa ...

随机推荐

  1. FastDFS安装和配置,整合Nginx-1.13.3

    目录: 一:下载FastDFS  二:安装FastDFS 三:配置 四:整合Nginx和FastDFS FastDFS is an open source high performance distr ...

  2. node 内存管理相关

    为什么在node中要担心node内存管理 使用JavaScript进行前端开发时几乎完全不需要关心内存管理问题,对于前端编程来说,V8限制的内存几乎不会出现用完的情况,v8在node中有着内存的限制( ...

  3. React Native 系列(二) -- React入门知识

    前言 本系列是基于React Native版本号0.44.3写的,最初学习React Native的时候,完全没有接触过React和JS,本文的目的是为了给那些JS和React小白提供一个快速入门,让 ...

  4. Bat脚本自动卸载软件-静默执行

    通过Bat脚本卸载软件,原理是得到某软件的ProductCode,然后通过MsiExec.exe命令卸载软件,下面是卸载一个产品的基本代码示例: set ML4.0HF4Name=Product4.0 ...

  5. 2016 "Bird Cup" ICPC7th@ahstu--“波导杯”安徽科技学院第七届程序设计大赛

    "波导杯"安徽科技学院第七届程序设计大赛 Contest - 2016 "Bird Cup" ICPC7th@ahstu Start time:  2016-0 ...

  6. 对接第三方平台JAVA接口问题推送和解决

    前言 本节所讲为实际项目中与第三方对接出现的问题最后还是靠老大解决了问题以此作为备忘录,本篇分为三小节,一小节解析Java加密接口数据,二小节解析XML文件需注意问题,最后一节则是请求Java Soa ...

  7. 疯狂的采药 洛谷p1616

    题目背景 此题为NOIP2005普及组第三题的疯狂版. 题目描述 LiYuxiang是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师.为此,他想拜附近最有威望的医师为师.医师为了判断他的资质,给他 ...

  8. [js高手之路] 跟GhostWu一起封装一个字符串工具库-架构篇(1)

    所谓字符串工具库就是利用javascript面向对象的知识封装一个常用的字符串处理方法库,首先给这个库起个名字,好吧就叫ghostwu.js. 看下ghostwu.js的整体架构: ; (functi ...

  9. python 项目中的 requirements.txt

    背景 java项目的话,包依赖一般都是maven管理,当然还有gradle,对于包的管理非常方便,maven的话只要在pom.xml中添加依赖包的maven坐标就可以了的,那python呢 ? 解决方 ...

  10. JavaWeb王者归来学习笔记

    JavaWeb王者归来学习笔记... Ajax王者归来: Ajax:Asynchronous JavaScript And XML -------Ajax 是一些旧有技术的结合.但却以一种新的姿态.披 ...