94_二叉树的中序遍历

简介: 94_二叉树的中序遍历

94_二叉树的中序遍历

 

package 二叉树.BT;
import java.util.ArrayList;
import java.util.Deque;
import java.util.LinkedList;
import java.util.List;
public class _94_二叉树的中序遍历 {
    public class TreeNode {
        int val;
        TreeNode left;
        TreeNode right;
        TreeNode() {
        }
        TreeNode(int val) {
            this.val = val;
        }
        TreeNode(int val, TreeNode left, TreeNode right) {
            this.val = val;
            this.left = left;
            this.right = right;
        }
    }
    // 递归实现的
    List<Integer> list = new ArrayList<>();
    public List<Integer> inorderTraversal(TreeNode root) {
        if(root == null) return list;
        inorderTraversal(root.left);
        //拿到当前结点
        list.add(root.val);
        inorderTraversal(root.right);
        return list;
    }
    // 迭代
    public List<Integer> inorderTraversal2(TreeNode root) {
        List<Integer> list2 = new ArrayList<>();
        if (root == null)
            return list2;
        Deque<TreeNode> stack = new LinkedList<>();
        TreeNode node = root;
        while(node != null || !stack.isEmpty() ) {
            while(node != null) {
                stack.push(node);
                node = node.left;
            }
            node = stack.pop();
            list2.add(node.val);    //已经拿到当前结点了    
            node = node.right;
        }
        return list2;
    }
}
目录
相关文章
|
8月前
二叉树的前序遍历、中序遍历、后序遍历
二叉树的前序遍历、中序遍历、后序遍历
|
8月前
|
存储
什么?二叉树的反前序遍历?
什么?二叉树的反前序遍历?
|
8月前
|
算法
二叉树中序遍历(一)
二叉树中序遍历(一)
|
8月前
|
C++
二叉树的前序遍历(C++)
二叉树的前序遍历(C++)
55 0
二叉树的前序遍历(C++)
|
8月前
二叉树的中序遍历
二叉树的中序遍历
48 0
|
8月前
|
C++
二叉树的后序遍历(C++)
二叉树的后序遍历(C++)
53 0
|
8月前
|
Linux
求二叉树的先序遍历
求二叉树的先序遍历
|
8月前
二叉树的前、中、后序遍历的实现
二叉树的前、中、后序遍历的实现