zoukankan      html  css  js  c++  java
  • 树的层次遍历

    说到树的层次遍历,就应该提到广度优先搜索算法------广度优先搜索算法(Breadth-First-Search),又译作宽度优先搜索,或横向优先搜索,简称BFS,是一种图形搜索算法。

             可以说树层次遍历是广度优先遍历的一种直接应用吧,比较广度优先搜索是图形的一种搜索算法,图形是一种比较大的概念,但这个和深度优先齐名的算法,在树的层次遍历引用中,并没有那么复杂,或许是因为用在树的遍历,而非图吧。

           树的层次遍历,故名思议,在一棵树中,把节点从左往右,一层一层的,从上往下,遍历输出,这里要用到一种很重要的数据结构,队列。

              步骤如下:

           1.首先将根节点放入队列中。 
           2.当队列为非空时,循环执行步骤3到步骤5,否则执行6; 
           3.出队列取得一个结点,访问该结点; 
           4.若该结点的左子树为非空,则将该结点的左子树入队列; 
           5.若该结点的右子树为非空,则将该结点的右子树入队列; 
           6.结束。

    import java.util.ArrayDeque;
    
    class TreeNode {
    
    	private TreeNode left = null;
    	private TreeNode right = null;
    	Integer val;
    
    	public TreeNode(Integer val) {
    		this.val = val;
    	}
    
    	public void setLeft(TreeNode node) {
    		this.left = node;
    	}
    
    	public void setRight(TreeNode node) {
    		this.right = node;
    	}
    
    	public static void BFSOrder(TreeNode node) {
    
    		if (node == null) {
    			return;
    		}
    
    		ArrayDeque<TreeNode> queue = new ArrayDeque<>();
    
    		queue.add(node);
    
    		while (!queue.isEmpty()) {
    
    			// 一定要放判定之前,否则会出大事
    			node = queue.poll();
    			System.out.print(node.val + " ");
    			if (node.left != null) {
    				queue.add(node.left);
    			}
    			if (node.right != null) {
    				queue.add(node.right);
    			}
    
    			// System.out.println(queue.poll().val + " ");
    		}
    	}
    }
    
    public class Solution {
    	public static void main(String[] args) {
    		TreeNode n1 = new TreeNode(1);
    		TreeNode n2 = new TreeNode(2);
    		TreeNode n3 = new TreeNode(3);
    		TreeNode n4 = new TreeNode(4);
    		TreeNode n5 = new TreeNode(5);
    		TreeNode n6 = new TreeNode(6);
    		TreeNode n7 = new TreeNode(7);
    
    		n1.setLeft(n2);
    		n1.setRight(n3);
    		n2.setLeft(n4);
    		n2.setRight(n5);
    		n3.setLeft(n6);
    		n4.setLeft(n7);
    
    		TreeNode.BFSOrder(n1);
    	}
    }
    

      

  • 相关阅读:
    运用 MyPasswordSafe 规画暗码
    用Solaris Express体验OS新功能
    Linux体系上安顿Flash Media Server
    LyX 宣布支持 CJK 的 1.5 正式版
    对Unix效能器制止机能监测(下)
    Oracle在Solaris下的机能与调整简介
    Linux据有率无望在2008年打破4%
    Fedora更符合做技术人用
    Gimmie — 一个创新的 GNOME 面板步调
    Sun推出OpenSolaris 为技术创新注入活力
  • 原文地址:https://www.cnblogs.com/figsprite/p/10666859.html
Copyright © 2011-2022 走看看