•   1. 存储图的方式一般是有两种的:邻接表和邻接矩阵,一般存储链接矩阵的方式是比较简单的,也便于我们去实现这个临接矩阵,他也就是通俗的二维数组,我们平常用到的那种。
  •   2. 这里我们主要记录和讲一下bfs和dfs算法之间的一些区别和用法,他们的原理一般人是都知道的,但是他们是怎么来实现的我相信一部分人并没有去真正的实现过,包括我也是(惭愧惭愧),本人算法比较渣,所以过来恶补一下。我就先从dfs开始吧。
    •   2.1 dfs 深度优先遍历

      •   顾名思义:深度优先,就是一直是往深处遍历,直到没有路走为止,再回过头来找到最开始那个没路的位置换一条路再进行上面那个操作,往深处钻。递归的方式比较简单,下面上一下代码,测试通过。
      • #include<iostream>
        #include <stdio.h>
        #include <string.h>
        #include <windows.h>
        #include <fstream>
        using namespace std; int array[][];
        bool visited[]; void input_graph(){ for (int i = ; i <= ; i++)
        for( int j = ; j <= ; j++)
        cin>>array[i][j];
        } void dfs_graph(){
        void dfs(int v);
        memset(visited, false, sizeof(visited)); for (int i = ; i <= ; i++)// 遍历每一个节点,主要是为了当图不是连通的时候无法访问所有的节点
        if(visited[i] == false)
        dfs(i);
        } void dfs(int v){
        //深度遍历每个节点,记录访问过的节点
        int adjx(int x); cout<<"当前访问顶点:"<<v<<endl;
        visited[v] = true; int adx = adjx(v);//求临接的顶点 while (adx!=){//这里就递归的进行深度搜索
        if(visited[adx] == false)
        dfs(adx); adx = adjx(v);
        }
        } int adjx(int x){//找到当前节点的临节点
        for (int i = ; i <= ; i++)
        if (array[x][i] == && visited[i] ==false)
        return i; return ;
        } int main(){
        cout<<"初始化图:"<<endl;
        input_graph(); cout<<"dfs遍历结果:"<<endl;
        dfs_graph(); return ;
        }
      •   我感觉递归的方式还是比较简单的,但是非递归的话比较麻烦,具体可以查看一个这位大哥写的。http://www.cnblogs.com/pengyingh/articles/2396432.html。写的通俗易懂挺好的。
    •   bfs 广度优先遍历
      •   这个就和深度不一样了,他这个就相当于是先遍历当前层的,然后再一层一层的往下面进行遍历,也是递归的方式。
      •   bfs算法其实就是一种层次遍历算法。从算法描述可以看到该算法要用到队列这一数据结构。我这

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

        #include<iostream>
        #include<queue>
        using namespace std; int a[][];
        bool visited[]; void store_graph()
        {
        for(int i=;i<=;i++)
        for(int j=;j<=;j++)
        cin>>a[i][j];
        } void bfs_graph()
        {
        void bfs(int v); memset(visited,false,sizeof(visited)); for(int i=;i<=;i++)
        if(visited[i]==false)
        bfs(i);
        } void bfs(int v)
        {
        int Adj(int x); queue<int> myqueue;
        int adj,temp; cout<<v<<" ";
        visited[v]=true;
        myqueue.push(v); while(!myqueue.empty()) //队列非空表示还有顶点未遍历到
        {
        temp=myqueue.front(); //获得队列头元素
        myqueue.pop(); //头元素出对 adj=Adj(temp);
        while(adj!=)
        {
        if(visited[adj]==false)
        {
        cout<<adj<<" ";
        visited[adj]=true;
        myqueue.push(adj); //进对
        } adj=Adj(temp);
        }
        }
        } int Adj(int x)
        {
        for(int i=;i<=;i++)
        if(a[x][i]== && visited[i]==false)
        return i; return ;
        } int main()
        {
        cout<<"初始化图:"<<endl;
        store_graph(); cout<<"bfs遍历结果:"<<endl;
        bfs_graph(); return ;
        }

dfs和bfs算法的更多相关文章

  1. 邻接表实现Dijkstra算法以及DFS与BFS算法

    //============================================================================ // Name : ListDijkstr ...

  2. 基本DFS与BFS算法(C++实现)

    样图: DFS:深度优先搜索,是一个不断探查和回溯的过程,每探查一步就将该步访问位置为true,接着在该点所有邻接节点中,找出尚未访问过的一个,将其作为下个探查的目标,接着对这个目标进行相同的操作,直 ...

  3. 图的DFS与BFS遍历

    一.图的基本概念 1.邻接点:对于无向图无v1 与v2之间有一条弧,则称v1与v2互为邻接点:对于有向图而言<v1,v2>代表有一条从v1到v2的弧,则称v2为v1的邻接点. 2.度:就是 ...

  4. 图的遍历算法:DFS、BFS

    在图的基本算法中,最初需要接触的就是图的遍历算法,根据访问节点的顺序,可分为深度优先搜索(DFS)和广度优先搜索(BFS). DFS(深度优先搜索)算法 Depth-First-Search 深度优先 ...

  5. BFS与DFS常考算法整理

    BFS与DFS常考算法整理 Preface BFS(Breath-First Search,广度优先搜索)与DFS(Depth-First Search,深度优先搜索)是两种针对树与图数据结构的遍历或 ...

  6. 【数据结构与算法笔记04】对图搜索策略的一些思考(包括DFS和BFS)

    图搜索策略 这里的"图搜索策略"应该怎么理解呢? 首先,是"图搜索",所谓图无非就是由节点和边组成的,那么图搜索也就是将这个图中所有的节点和边都访问一遍. 其次 ...

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

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

  8. 图论中DFS与BFS的区别、用法、详解?

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

  9. BFS算法(——模板习题与总结)

    首先需要说明的是BFS算法(广度优先算法)本质上也是枚举思想的一种体现,本身效率不是很高,当数据规模很小的时候还是可以一试的.其次很多人可能有这样的疑问,使用搜索算法的时候,到底选用DFS还是BFS, ...

随机推荐

  1. 转载:电商项目完成的BUG调查原因和解决方案

    转载: http://blog.csdn.net/yuexianchang/article/details/73197874

  2. RabbitMQ在windows环境下的安装

    最近一直想入手一台电脑,作为linux服务器,由于经济状况也没有入手,现在就先介绍windows环境下安装rabbitMQ. RabbitMQ是什么 ? RabbitMQ是一个在AMQP基础上完整的, ...

  3. 基于spring及zookeeper的dubbo工程搭建

    一.生产者搭建 新建一个maven工程,勾选Create a simple project Packaging方式选择jar包的方式. 修改pom.xml文件: <project xmlns=& ...

  4. kindeditro.js乱码问题

    kindeditor.js是用于显示新建邮件时的菜单栏的一个插件,比较好用,但是在引入的时候会出现乱码问题,主要有几个方面原因. 1.编码方式不对,要设置成utf8. <script chars ...

  5. h5的video标签支持的视频格式

    关于<video>标签所支持的视频格式和编码: MP4 = MPEG 4文件使用 H264 视频编解码器和AAC音频编解码器 WebM = WebM 文件使用 VP8 视频编解码器和 Vo ...

  6. Powershell使用SSH

    在编写Powershell脚本时,有时会需要和Linux机器进行交互.所以这时就需要在Powershell中使用SSH. 本文将介绍如何在Powershell中安装SSH模块,以及如何使用ssh命令. ...

  7. vijos1264:神秘的咒语

    描述 身为拜月教的高级间谍,你的任务总是逼迫你出生入死.比如这一次,拜月教主就派你跟踪赵灵儿一行,潜入试炼窟底. 据说试炼窟底藏着五行法术的最高法术:风神,雷神,雪妖,火神,山神的咒语.为了习得这些法 ...

  8. mvn + idea jar包配置 错误记录

    1.创建项目方法和步骤,网上一搜一大把 2.主要出现了一个配置上的错误,java_home的配置 发现idea和eclipse有一个地方配置不同,就是java_home,在eclipse中 mvn的配 ...

  9. Regexp:template

    ylbtech-Regexp: 1.返回顶部 1.   2. 2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部     6.返回顶部   7.返回顶部   8.返回顶部   9.返回 ...

  10. 50 states of America

    美国州名 州名英文  州名音标 简写 首府 首府 阿拉巴马州 Alabama   [ˌæləˈbæmə] AL 蒙哥马利 Montgomery[mənt'gʌməri] 阿拉斯加州 Alaska  [ ...