ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

p34 二叉树的后续遍历 (leetcode 145)

2020-03-14 18:01:54  阅读:224  来源: 互联网

标签:145 TreeNode ret leetcode 二叉树 push root stack postorder


一:解题思路

这道题目有2种方法,第一种是递归法,第二种是迭代法。2种方法的时间和空间复杂度都为O(n)。

二:完整代码示例 (C++版和Java版)

递归C++:

class Solution 
{
public:
    void postorder(TreeNode* root, vector<int>& ret)
    {
        if (root != NULL)
        {
            postorder(root->left,ret);
            postorder(root->right,ret);
            ret.push_back(root->val);
        }
    }

    vector<int> postorderTraversal(TreeNode* root) 
    {
        vector<int> ret;

        postorder(root,ret);

        return ret;
    }
};

递归Java:

class Solution {
    public void postorder(TreeNode root,List<Integer> ret)
    {
        if(root!=null)
        {
            postorder(root.left,ret);
            postorder(root.right,ret);
            ret.add(root.val);
        }
    }
    
    public List<Integer> postorderTraversal(TreeNode root) 
    {
           List<Integer> ret=new ArrayList<>();

           postorder(root,ret);
           
           return ret;
    }
}

迭代C++:

class Solution 
{
public:
    vector<int> postorderTraversal(TreeNode* root) 
    {
        vector<int> ret;
        stack<TreeNode*> stack;
        list<int> list;

        if (root != NULL)
            stack.push(root);
        
        while (!stack.empty())
        {
            TreeNode* s = stack.top();
            stack.pop();

            list.push_front(s->val);

            if (s->left != NULL)  stack.push(s->left);
            if (s->right != NULL) stack.push(s->right);
        }

        while (!list.empty())
        {
            ret.push_back(list.front());
            list.pop_front();
        }

        return ret;
    }
};

迭代Java:

class Solution {
    public List<Integer> postorderTraversal(TreeNode root)
    {
           LinkedList<Integer> ret=new LinkedList<>();
           Stack<TreeNode> stack=new Stack<>();
           
           if(root!=null)
               stack.push(root);
           
           while(!stack.isEmpty())
           {
               TreeNode s=stack.pop();
               ret.addFirst(s.val);
               
               if(s.left!=null)  stack.push(s.left);
               if(s.right!=null) stack.push(s.right);
           }
           
           return ret;
    }
}

 

标签:145,TreeNode,ret,leetcode,二叉树,push,root,stack,postorder
来源: https://www.cnblogs.com/repinkply/p/12493335.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有