LeetCode刷题笔记day16-中序遍历(递归和非递归实现)

递归方式这里不做详细的介绍
递归代码:

class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
        List<Integer> list = new LinkedList<Integer>();
        treaversal(root,list);
        return list;

    }
    public void treaversal(TreeNode root,List list){
          if(root==null){
              return;
          }
          treaversal(root.left,list);
          list.add(root.val);
          treaversal(root.right,list);
    }
}

非递归实现:
首先还是利用栈这种数据结构,中序遍历的逻辑顺序为左中右,首先判断迭代是否结束的标志是栈是否为空,如果节点元素的左节点不为空,则一直让左节点进栈,直到左节点为空为止,如果元素左节点为空之后则,让该节点出栈,让该节点的父亲节点出栈,然后让父亲节点的右节点进栈,重复以上过程。

class Solution {
    public List<Integer> inorderTraversal(TreeNode root) {
        Stack<TreeNode> stack = new Stack<>();
        ArrayList<Integer> list = new ArrayList<>();
      if(root==null){
          return list;
      }
      TreeNode cur = root;
      while(!stack.isEmpty()|| cur!=null){
          if(cur!=null){
              stack.push(cur);
              cur = cur.left;
          }
          else{
                      cur  = stack.pop();
                      list.add(cur.val);
                      cur = cur.right;
          }
      }
      return list;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值