力扣hot100 - 144、二叉树的前序遍历

题目:

法一:递归

法二:迭代

整体思路:先将根节点放入栈中,弹出并放入结果集合,再将右、左孩子放入栈,弹出一个并且放入结果集合,将弹出的节点有左孩子放入栈中。为什么是先右后左?弹出时刚好是先左后右。

java 复制代码
/**
 * Definition for a binary tree node.
 * 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;
 *     }
 * }
 */
class Solution {
    public List<Integer> preorderTraversal(TreeNode root) {
        List<Integer> result = new ArrayList();
        Deque<TreeNode> stack = new ArrayDeque();
        if(root == null) return result;
        stack.push(root);

        while(!stack.isEmpty()){
            TreeNode node = stack.peek();
            stack.pop();
            if(node != null){
                result.add(node.val);
                if(node.right != null){
                    stack.push(node.right);
                }
                if(node.left != null){
                     stack.push(node.left);
                }
            
            }else{
                continue;
            }
        }

        return result;
    }
}
相关推荐
范纹杉想快点毕业2 小时前
嵌入式系统架构之道:告别“意大利面条”,拥抱状态机与事件驱动
java·开发语言·c++·嵌入式硬件·算法·架构·mfc
近津薪荼2 小时前
递归专题(4)——两两交换链表中的节点
数据结构·c++·学习·算法·链表
2501_940315262 小时前
【无标题】2390:从字符串中移除*
java·开发语言·算法
乐观勇敢坚强的老彭2 小时前
c++寒假营day01下午
c++·算法
散峰而望2 小时前
【算法竞赛】树
java·数据结构·c++·算法·leetcode·贪心算法·推荐算法
鱼很腾apoc2 小时前
【实战篇】 第14期 算法竞赛_数据结构超详解(下)
c语言·开发语言·数据结构·学习·算法·青少年编程
123_不打狼2 小时前
AE(自编码器)与 VAE(变分自编码器)核心区别:原理、目标与应用
深度学习·算法·机器学习·vae
Anastasiozzzz2 小时前
LeetCode hot100 45 跳跃游戏2
算法·leetcode·游戏
近津薪荼3 小时前
递归专题(3)——反转链表
数据结构·c++·学习·算法·链表