DFS(深度优先搜索)和BFS(广度优先搜索)

深度优先搜索算法(Depth-First-Search)
深度优先搜索算法(Depth-First-Search),是搜索算法的一种。它沿着树的深度遍历树的节点,尽可能深的搜索树的分 支。
当节点v的所有边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。
这一过程一直进行到已发现从源节点可达的所有节点为止。
如果还存在未被发 现的节点,则选择其中一个作为源节点并重复以上过程,整个进程反复进行直到所有节点都被访问为止。
深度优先搜索是图论中的经典算法,利用深度优先搜索算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图论问题,如最大路径问题等等。一般用堆数据结构来辅助实现DFS算法。

DFS属于盲目搜索##

**深度优先遍历图算法步骤:

  1. 访问顶点v;
  2. 依次从v的未被访问的邻接点出发,对图进行深度优先遍历;直至图中和v有路径相通的顶点都被访问;
  3. 若此时图中尚有顶点未被访问,则从一个未被访问的顶点出发,重新进行深度优先遍历,直到图中所有顶点均被访问过为止。
         >上述描述可能比较抽象,举个实例:

DFS 在访问图中某一起始顶点 v 后,由 v 出发,访问它的任一邻接顶点 w1;再从 w1 出发,访问与 w1邻 接但还没有访问过的顶点 w2;然后再从 w2 出发,进行类似的访问,… 如此进行下去,直至到达所有的邻接顶点都被访问过的顶点 u 为止。
接着,退回一步,退到前一次刚访问过的顶点,看是否还有其它没有被访问的邻接顶点。如果有,则访问此顶点,之后再从此顶点出发,进行与前述类似的访问;如果没有,就再退回一步进行搜索。重复上述过程,直到连通图中所有顶点都被访问过为止。

例如下图,其深度优先遍历顺序为 1->2->4->8->5->3->6->7


Paste_Image.png

广度优先搜索算法(Breadth-First-Search)

广度优先搜索算法(Breadth-First-Search),是一种图形搜索算法

简单的说,BFS是从根节点开始,沿着树(图)的宽度遍历树(图)的节点。
如果所有节点均被访问,则算法中止。
BFS同样属于盲目搜索。
一般用队列数据结构来辅助实现BFS算法。

算法步骤:

  1. 首先将根节点放入队列中。
  2. 从队列中取出第一个节点,并检验它是否为目标。如果找到目标,则结束搜寻并回传结果。否则将它所有尚未检验过的直接子节点加入队列中。
  3. 若队列为空,表示整张图都检查过了——亦即图中没有欲搜寻的目标。结束搜寻并回传“找不到目标”。
  4. 重复步骤2。

如下图,其广度优先算法的遍历顺序为:1->2->3->4->5->6->7->8

Paste_Image.png

java实现代码

              import java.util.ArrayDeque;
              public class BinaryTree { 
                  static class TreeNode{ 
                        int value; 
                        TreeNode left; 
                        TreeNode right; 
                        public TreeNode(int value){ 
                            this.value=value;
                           } 
                  }

              TreeNode root;
              public BinaryTree(int[] array){
                         root=makeBinaryTreeByArray(array,1); 
              }
          /** 
           * 采用递归的方式创建一颗二叉树 
           * 传入的是二叉树的数组表示法 
           * 构造后是二叉树的二叉链表表示法 
           */
          public static TreeNode makeBinaryTreeByArray(int[] array,int index){ 
                  if(index<array.length){ 
                          int value=array[index]; 
                          if(value!=0){ 
                                TreeNode t=new TreeNode(value); 
                                array[index]=0;                                       
                                t.left=makeBinaryTreeByArray(array,index*2);                           
                                t.right=makeBinaryTreeByArray(array,index*2+1);                     
                                return t; 
                          }
                   } 
                  return null; 
            }

       /** 
          * 深度优先遍历,相当于先根遍历 
          * 采用非递归实现 
          * 需要辅助数据结构:栈 
          */
        public void depthOrderTraversal(){ 
                    if(root==null){ 
                      System.out.println("empty tree"); 
                      return; 
                    } 
                    ArrayDeque<TreeNode> stack=new ArrayDeque<TreeNode>(); 
                    stack.push(root); 
                    while(stack.isEmpty()==false){ 
                        TreeNode node=stack.pop();   
                         System.out.print(node.value+" ");
                         if(node.right!=null){ 
                              stack.push(node.right); 
                          }
                         if(node.left!=null){ 
                              stack.push(node.left); 
                          } 
                  } 
                  System.out.print("\n");
             }
 /** 
  * 广度优先遍历 
  * 采用非递归实现 
  * 需要辅助数据结构:队列 
  */
       public void levelOrderTraversal(){ 
                  if(root==null){ 
                     System.out.println("empty tree"); 
                      return; 
                  } 
                  ArrayDeque<TreeNode> queue=new ArrayDeque<TreeNode>(); 
                  queue.add(root); 
                  while(queue.isEmpty()==false){ 
                      TreeNode node=queue.remove(); 
                      System.out.print(node.value+" ");
                      if(node.left!=null){ 
                            queue.add(node.left);
                       }
                     if(node.right!=null){ 
                           queue.add(node.right); 
                      } 
                  }
                 System.out.print("\n");
       }
   /** 
     * 13 
     * / \ 
     * 65 5 
     * / \ \ 
     * 97 25 37 
     * / /\ / 
     * 22 4 28 32 
     */
     public static void main(String[] args) { 
              int[] arr={0,13,65,5,97,25,0,37,22,0,4,28,0,0,32,0}; 
              BinaryTree tree=new BinaryTree(arr);                       
              tree.depthOrderTraversal(); 
              tree.levelOrderTraversal(); 
     }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,016评论 0 12
  • 第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章...
    SeanCheney阅读 5,660评论 0 19
  • 1 概述 图是数据结构中最复杂的形式,也是最烧脑的结构。无数的牛人乐此不疲地钻研,然而,时至今日,依然有很多问题等...
    CodingTech阅读 2,217评论 0 8
  • https://zh.visualgo.net/graphds 浅谈图形结构https://zh.visualgo...
    狼之独步阅读 3,980评论 0 0
  • 图是一种比线性表和树更复杂的数据结构,在图中,结点之间的关系是任意的,任意两个数据元素之间都可能相关。图是一种多对...
    Alent阅读 2,236评论 1 22