码迷,mamicode.com
首页 > 其他好文 > 详细

二叉树的非递归遍历

时间:2020-05-01 11:01:06      阅读:50      评论:0      收藏:0      [点我收藏+]

标签:int   new   lse   post   递归   遍历   else   pre   非递归遍历   



1. 递归实现


先序

public void preOrder(){
    preOrder(root);
}
private void preOrder(Node node){
    if(node != null){
        System.out.println(node.value);
        preOrder(node.left);
        preOrder(node.right);
    }
}

中序

public void midOrder(){
    midOrder(root);
}
private void midOrder(Node node){
    if(node != null){
        midOrder(node.left);
        System.out.println(node.value);
        midOrder(node.right);
    }
}

后序

public void postOrder(){
    postOrder(root);
}
private void postOrder(Node node){
    if(node != null){
        postOrder(node.left);
        postOrder(node.right);
        System.out.println(node.value);
    }
}




2. 非递归


前序

public void preOrderNew(){
    preOrderNew(root);
}
private void preOrderNew(Node node){
    if(node != null){
        LinkedList<Node> list = new LinkedList();
        list.addFirst(node);

        while(!list.isEmpty()){
            Node temp = (Node) list.removeFirst();
            if(temp.right != null){
                list.addFirst(temp.right);
            }
            if(temp.left != null){
                list.addFirst(temp.left);
            }
            System.out.println(temp.value);
        }
    }
}

中序

public void midOrderNew(){
    midOrderNew(root);
}
private void midOrderNew(Node node){
    LinkedList<Node> list = new LinkedList();
    while(!list.isEmpty() || node != null){
        if(node != null){
            list.addFirst(node);
            node = node.left;
        }else{
            node = list.removeFirst();
            System.out.println(node.value);
            node = node.right;
        }
    }
}

后序

public void postOrderNew(){
    postOrderNew(root);
}
private void postOrderNew(Node node){
    if(node != null){
        LinkedList<Node> list1 = new LinkedList();
        LinkedList<Node> list2 = new LinkedList();
        list1.addFirst(node);

        while(!list1.isEmpty()){
            Node temp = list1.removeFirst();
            list2.addFirst(temp);
            if(temp.left != null){
                list1.addFirst(temp.left);
            }
            if(temp.right != null){
                list1.addFirst(temp.right);
            }
        }
        while(!list2.isEmpty()){
            Node temp = list2.removeFirst();
            System.out.println(temp.value);
        }
    }
}


二叉树的非递归遍历

标签:int   new   lse   post   递归   遍历   else   pre   非递归遍历   

原文地址:https://www.cnblogs.com/Howlet/p/12812648.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!