`
xiaobai233
  • 浏览: 59826 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

二叉树遍历

 
阅读更多
public class BinaryTree {   
      // Root node pointer. Will be null for an empty tree.   
      private Node root ;   
      private static class Node {   
          Node left ;   
          Node right ;   
          int data ;   
          Node( int newData) {   
              left = null ;   
              right = null ;   
              data = newData;   
          }   
      }   
      /**  
       Creates an empty binary tree -- a null root pointer.  
      */  
  
      public BinaryTree() {   
          root = null ;   
      }   
      /**  
       Inserts the given data into the binary tree.  
       Uses a recursive helper.  
      */  
      public void insert( int data) {   
//      System.out.println(data);   
        root = insert( root , data);   
      }   
      /**  
       Recursive insert -- given a node pointer, recur down and  
       insert the given data into the tree. Returns the new  
       node pointer (the standard way to communicate  
       a changed pointer back to the caller).  
       二叉搜索树  
      */  
  
      private Node insert(Node node, int data) {             
        if (node== null ) {   
          node = new Node(data);   
        }else {   
          if (data <= node. data ) {   
//            System.out.println("left:"+data);   
            node. left = insert(node. left , data);            
          }else {   
//              System.out.println("right:"+data);   
            node. right = insert(node. right , data);   
  
          }   
        }   
        return (node); // in any case, return the new pointer to the caller   
      }   
  
      public void buildTree( int [] data){   
          for ( int i=0;i<data.length ;i++){   
             insert(data[i]);   
          }    
  
      }   
  
      public void printTree() {   
          afterErgodic( root );   
          System. out .println();   
         }   
  
      private void printTree(Node node) {   
          if (node == null ) return ;   
          // left, node itself, right   
          printTree(node. left );   
          System. out .print(node. data + "  " );            
          printTree(node. right );   
         }   
  
      /**  
       * 先序遍历  
       * @param node  
       */  
      public void preErgodic(Node node){   
          if(node==null){   
              return;   
          }   
          Stack sk=new Stack();   
          Node p=node;   
          while(p!=null){   
              //把p节点的左子树的左子树的值获取出来   
              //把p节点的右子节点入栈,最上面的是右叶子节点   
              //栈底的节点为根的右子节点   
              while(p!=null){   
                  System.out.print(p.data+" ");   
                  //右子树入栈   
                  if(p.right!=null) sk.push(p.right);   
                  //进入下一个左子树   
                  p=p.left;   
              }   
              //遍历右子树,从右叶子节点开始,然后往上,若有左子节点,则执行上面的while步骤   
              if(!sk.isEmpty()){   
                  //进入下一个右子树   
                  p=(Node)sk.pop();   
//                System.out.print(p.data+ " ");   
              }   
          }   
      }   
       
      /**  
       * 中序遍历  
       * @param node  
       */  
      public void centerErgodic(Node node){   
          if(node==null){   
              return;   
          }   
          Stack sk=new Stack();   
          Node p=node;   
          while(p!=null||!sk.isEmpty()){   
              //把p节点的左子节点入栈,最上面的是左叶子节点   
              while(p!=null){   
                  sk.push(p);   
                  p=p.left;   
              }   
              //第一步是先把左叶子节点出栈,此时右节点为null   
              //第二步是把左叶子节点的父节点出栈,此时的右节点则是右叶子节点   
              //第三步则是把左叶子节点的父节点的父节点出栈,此时右节点含有子节点   
              //第四步开始则是对右节点开始遍历,步骤则是重复前三步   
              //第五步则是重复执行第三步和第四步,直到sk里面无节点为止   
              if(!sk.isEmpty()){   
                  p=(Node)sk.pop();   
                  System.out.print(p.data+" ");   
                  p=p.right;   
              }   
          }   
      }   
      /**  
       * 后序遍历  
       * @param node  
       */  
      public void afterErgodic(Node node){   
          if(node==null){   
              return;   
          }   
          Stack sk=new Stack();   
          Node p=node;   
             
          while(p!=null||!sk.isEmpty()){   
              //先左后右不断深入   
              while(p!=null){   
                  sk.push(p);//将根节点入栈   
                  if(p.left!=null) p=p.left;   
                  else p=p.right;   
              }   
                 
              //这里主要是叶子节点的获取   
              if(!sk.isEmpty()){   
                  p=(Node)sk.pop();   
                  System.out.print(p.data+" ");                  
              }   
                 
              //满足条件时,说明栈顶根节点右子树已访问,应出栈访问之   
              //这里肯定是非叶子节点   
              while(!sk.isEmpty()&&((Node)sk.peek()).right==p){   
                  p=(Node)sk.pop();   
                  System.out.print(p.data+" ");   
              }   
              //转向栈顶根节点的右子树继续后序遍历   
              if(!sk.isEmpty()) p=((Node)sk.peek()).right;   
              else p=null;               
          }   
      }   
         
      /**  
       * 另外一种建立二叉树的方法,非递归形式  
       * @param data  
       */  
      public void createBinary(int[] data){   
          Node temp = null;              
          for(int i=0;i<data.length;i++){   
              // 创建根节点    
              if(root==null){   
                  root = temp = new Node(data[i]);    
              }else{   
                // 回到根结点   
                  temp=root;   
                  // 添加节点      
                  while (temp.data != data[i]) {      
                      if(temp.data>data[i]){//左子树                             
                          if (temp.left != null) {   
//                            System.out.println(data[i]+" "+22);   
                              //如果有左子树,则把左子树赋值给temp,此次while循环结束,开始下次循环。   
                              //直到没有左子树为止,即新增加一个左子树   
                              temp = temp.left;   
                          }else{   
                              //新增左子树   
//                            System.out.println(data[i]+" "+11);   
                              temp.left=new Node(data[i]);   
                              //这里可以减少循环的次数,新增之后再判断时则会跳出循环   
                              temp = temp.left;   
                          }   
                      }else{//右子树   
                          if(temp.right!=null){   
                              //同左子树   
                              temp = temp.right;     
                          }else{   
                              temp.right=new Node(data[i]);   
                              //同上   
                              temp = temp.right;     
                          }   
                      }   
                  }   
              }          
          }   
//        return root;   
      }   
         
         
    /**  
     * @param args  
     */  
    public static void main(String[] args) {   
        BinaryTree bt=new BinaryTree();   
        //数据貌似不能是排好序的,但必须有顺序,貌似是前序遍历的顺序   
        int[] array={4, 2, 6, 1, 3, 5, 7};   
//      bt.buildTree(array);   
        bt.createBinary(array);   
        bt.printTree();   
//      #      4   
//      #    /    \   
//      #   2      6   
//      #  / \    / \   
//      # 1  3   5   7    
//      # 前序遍历:4 2 1 3 6 5 7      
//      # 中序遍历:1 2 3 4 5 6 7      
//      # 后序遍历:1 3 2 5 7 6 4      
    }   
  
}  

分享到:
评论

相关推荐

    二叉树遍历的特点(数据结构)C语言描述

    ### 二叉树遍历的特点(数据结构) 在计算机科学领域,数据结构是研究的核心之一。其中,二叉树作为一种重要的非线性数据结构,在实际应用中极为广泛,包括搜索算法、排序算法等方面都有其身影。本文将详细介绍...

    【C语言二叉树遍历实例】C语言二叉树遍历实例

    二叉树的遍历C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历实例C语言二叉树遍历...

    易语言二叉树遍历

    二叉树遍历是理解数据结构和算法的基础,它包括前序遍历、中序遍历和后序遍历三种主要方法。 1. **二叉树的基本概念**: - 二叉树是一种特殊的树结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。 -...

    数据结构 二叉树遍历程序

    二叉树遍历是理解二叉树操作的关键部分,主要包括先序遍历、中序遍历和后序遍历三种方式。 1. 先序遍历(Preorder Traversal): 先序遍历的顺序是根节点 -&gt; 左子树 -&gt; 右子树。在C语言实现中,一般采用递归的方法...

    二叉树遍历算法的应用

    二叉树遍历算法在IT领域中是一种基础且重要的数据结构操作技术,广泛应用于各种问题的解决。在本文中,我们将深入探讨二叉树遍历的原理及其在统计二叉树节点数量、叶子节点计数以及计算树深等方面的应用。 二叉树...

    堆栈实现二叉树遍历数据结构C语言

    从给定的文件信息来看,该文件主要围绕“堆栈实现二叉树遍历数据结构”的主题,通过C语言编程来实现。以下是基于标题、描述、标签和部分内容的知识点总结和详细说明: ### 1. 数据结构基础 数据结构是计算机科学的...

    实现先序,中序和后序遍历的二叉树遍历程序

    二叉树遍历是针对这种数据结构的一种基本操作,用于按照特定顺序访问树中的所有节点。本程序实现了三种主要的二叉树遍历方法:先序遍历、中序遍历和后序遍历。以下是关于这些遍历方法的详细解释: 1. 先序遍历...

    数据结构树和二叉树遍历二叉树和线索二叉树PPT学习教案.pptx

    "数据结构树和二叉树遍历二叉树和线索二叉树PPT学习教案.pptx" 本资源主要讲述了数据结构树和二叉树遍历的相关知识点,包括二叉树的基本概念、二叉树遍历的六种方案、先序、中序、后序遍历算法的实现、线索二叉树的...

    数据结构实验-3二叉树遍历与路径查找(二叉树实验)

    实验三 二叉树遍历与路径查找(二叉树实验) 实现功能:建立二叉树存储结构、求二叉树的先序遍历、求二叉树的中序遍历、求二叉树的后序遍历、求二叉树的层次遍历、求根到给定结点的路径。 主控菜单: 1.建立二叉树...

    matlab实现二叉树遍历算法(源代码)

    ### MATLAB 实现二叉树遍历算法的知识点详解 #### 一、二叉树节点结构体定义 在MATLAB中实现二叉树的第一步是定义一个表示二叉树节点的结构体。在这个例子中,作者定义了一个名为`TreeNode`的类来表示节点,该类...

    数据结构 二叉树遍历

    #### 1.2 二叉树遍历 遍历是指按照某种顺序访问二叉树中的所有节点,且每个节点只被访问一次的过程。二叉树常见的遍历方式包括:先序遍历、中序遍历和后序遍历。 ### 二、二叉树遍历方法 #### 2.1 先序遍历(前序...

    二叉树遍历的算24程序

    java 写的算24程序。用两种二叉树遍历,并规整输出字符串

    二叉树遍历 二叉树遍历

    二叉树遍历 二叉树遍历

    二叉树遍历流程图(先序、中序、后序、宽度遍历)

    二叉树遍历是计算机科学中处理树结构数据时常用的一种技术,主要分为四种类型:先序遍历、中序遍历、后序遍历和宽度优先遍历。这些遍历方法各有特点,适用于不同的场景。 1. **先序遍历**: - **递归实现**:先...

    二叉树遍历(递归算法)

    二叉树遍历是计算机科学中数据结构领域的一个重要概念,尤其在算法设计与分析中占有举足轻重的地位。二叉树是一种特殊的图结构,每个节点最多有两个子节点,通常分为左子节点和右子节点。二叉树遍历是指按照特定顺序...

    二叉树遍历问题-二叉树遍历问题

    二叉树遍历是计算机科学中的一个重要概念,主要应用于数据结构和算法领域。二叉树是一种特殊的树形数据结构,每个节点最多有两个子节点,通常称为左子节点和右子节点。二叉树遍历是指按照特定顺序访问二叉树的所有...

    二叉树遍历问题-前序, 中序, 后序

    二叉树遍历问题 二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序, 中序, 后序二叉树遍历问题-前序...

    二叉树遍历操作.cpp

    二叉树遍历操作.cpp

Global site tag (gtag.js) - Google Analytics