当前位置:   article > 正文

二叉树的前序遍历(LeetCode)_编写一段程序,前序遍历二叉树

编写一段程序,前序遍历二叉树

题目链接

题目描述

给定一个二叉树,返回它的 前序 遍历。

示例:

输入: [1,null,2,3]  
   1
    \
     2
    /
   3 

输出: [1,2,3]
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

进阶: 递归算法很简单,你可以通过迭代算法完成吗?

思路

用栈模拟即可,因为栈后进先出,所以要先放右子节点再放左子节点。

class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
        if(!root)
            return vector<int>();
        stack<TreeNode *> s;
        vector<int> ans;
        s.push(root);
        while(!s.empty()){
            TreeNode *top=s.top();
            s.pop();
            ans.push_back(top->val);
            if(top->right)
                s.push(top->right);
            if(top->left)
                s.push(top->left);
        }
        return ans;
    }
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/668792
推荐阅读
相关标签
  

闽ICP备14008679号