zoukankan      html  css  js  c++  java
  • 二叉树的递归,非递归遍历(java)

      1 import java.util.Stack;
      2 import java.util.HashMap;
      3 
      4 public class BinTree {
      5     private char date;
      6     private BinTree lchild;
      7     private BinTree rchild;
      8 
      9     public BinTree(char c) {
     10         date = c;
     11     }
     12 
     13     // 先序遍历递归
     14     public static void preOrder(BinTree t) {
     15         if (t == null) {
     16             return;
     17         }
     18         System.out.print(t.date);
     19         preOrder(t.lchild);
     20         preOrder(t.rchild);
     21     }
     22 
     23     // 中序遍历递归
     24     public static void InOrder(BinTree t) {
     25         if (t == null) {
     26             return;
     27         }
     28         InOrder(t.lchild);
     29         System.out.print(t.date);
     30         InOrder(t.rchild);
     31     }
     32 
     33     // 后序遍历递归
     34     public static void PostOrder(BinTree t) {
     35         if (t == null) {
     36             return;
     37         }
     38         PostOrder(t.lchild);
     39         PostOrder(t.rchild);
     40         System.out.print(t.date);
     41     }
     42 
     43     // 先序遍历非递归
     44     public static void preOrder2(BinTree t) {
     45         Stack<BinTree> s = new Stack<BinTree>();
     46         while (t != null || !s.empty()) {
     47             while (t != null) {
     48                 System.out.print(t.date);
     49                 s.push(t);
     50                 t = t.lchild;
     51             }
     52             if (!s.empty()) {
     53                 t = s.pop();
     54                 t = t.rchild;
     55             }
     56         }
     57     }
     58 
     59     // 中序遍历非递归
     60     public static void InOrder2(BinTree t) {
     61         Stack<BinTree> s = new Stack<BinTree>();
     62         while (t != null || !s.empty()) {
     63             while (t != null) {
     64                 s.push(t);
     65                 t = t.lchild;
     66             }
     67             if (!s.empty()) {
     68                 t = s.pop();
     69                 System.out.print(t.date);
     70                 t = t.rchild;
     71             }
     72         }
     73     }
     74 
     75     // 后序遍历非递归
     76     public static void PostOrder2(BinTree t) {
     77         Stack<BinTree> s = new Stack<BinTree>();
     78         Stack<Integer> s2 = new Stack<Integer>();
     79         Integer i = new Integer(1);
     80         while (t != null || !s.empty()) {
     81             while (t != null) {
     82                 s.push(t);
     83                 s2.push(new Integer(0));
     84                 t = t.lchild;
     85             }
     86             while (!s.empty() && s2.peek().equals(i)) {
     87                 s2.pop();
     88                 System.out.print(s.pop().date);
     89             }
     90 
     91             if (!s.empty()) {
     92                 s2.pop();
     93                 s2.push(new Integer(1));
     94                 t = s.peek();
     95                 t = t.rchild;
     96             }
     97         }
     98     }
     99 
    100     public static void main(String[] args) {
    101         BinTree b1 = new BinTree('a');
    102         BinTree b2 = new BinTree('b');
    103         BinTree b3 = new BinTree('c');
    104         BinTree b4 = new BinTree('d');
    105         BinTree b5 = new BinTree('e');
    106 
    107         /**
    108          *      a 
    109          *     / /
    110          *    b   c
    111          *   / /
    112          *  d   e
    113          */
    114         b1.lchild = b2;
    115         b1.rchild = b3;
    116         b2.lchild = b4;
    117         b2.rchild = b5;
    118 
    119         BinTree.preOrder(b1);
    120         System.out.println();
    121         BinTree.preOrder2(b1);
    122         System.out.println();
    123         BinTree.InOrder(b1);
    124         System.out.println();
    125         BinTree.InOrder2(b1);
    126         System.out.println();
    127         BinTree.PostOrder(b1);
    128         System.out.println();
    129         BinTree.PostOrder2(b1);
    130     }
    131 }
  • 相关阅读:
    UWP关于图片缓存的那些破事儿
    UWP中的文件相关操作
    数据结构-快速排序(C#实现)
    C#与Swift异步操作的差异
    Windows环境下使用Clover四叶草引导双硬盘安装OSX 10.11.5原版镜像
    Winform以任意角度旋转PictureBox中的图片的方法
    Xcode调用旧版本库出现Undefined symbols for architecture x86_64: ld: symbol(s) not found for architecture x86_64
    做WP程序时遇到的一些问题及解决方法
    WInform关闭程序的几种方法以及区别。
    显示在标题上的进度条
  • 原文地址:https://www.cnblogs.com/WayneZeng/p/3409285.html
Copyright © 2011-2022 走看看