C++ 二叉树的前序遍历 - 力扣(LeetCode)

点击链接即可查看题目: 144. 二叉树的前序遍历 - 力扣(LeetCode)

一、题目

给你二叉树的根节点 root ,返回它节点值的 前序 遍历。

示例 1:

**输入:**root = 1,null,2,3

输出:1,2,3

解释:

示例 2:

**输入:**root = 1,2,3,4,5,null,8,null,null,6,7,9

输出:1,2,4,5,6,7,3,8,9

解释:

示例 3:

**输入:**root = \[\]

输出:\[\]

示例 4:

**输入:**root = 1

输出:1

提示:

  • 树中节点数目在范围 [0, 100]
  • -100 <= Node.val <= 100

二、解题思路以及代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */



class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) 
    {
        stack<TreeNode*> st;
        vector<int> v;
        //先访问左路节点
        
        TreeNode* cur = root;
        while(cur || !st.empty())
        {
            while(cur)
            {
                //左路节点访问,并且入栈
                st.push(cur);
                v.push_back(cur->val);
                cur = cur->left;
            }
            //子问题访问右子树
            TreeNode* top = st.top();
            cur = top->right;
            st.pop();
        }
        return v;
    }
};
相关推荐
郝学胜_神的一滴7 分钟前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
To_OC11 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
To_OC2 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
博客18002 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴2 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
众少成多积小致巨3 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
clint4567 天前
C++进阶(1)——前景提要
c++
夜悊7 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴7 天前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0018 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp