leetcode算法145.二叉树的后序遍历
2023-09-11 14:22:53 时间
👏👏👏
哈喽!大家好,我是【学无止境小奇】,一位热爱分享各种技术的博主!😍😍😍
⭐【学无止境小奇】的创作宗旨:每一条命令都亲自执行过,每一行代码都实际运行过,每一种方法都真实实践过,每一篇文章都良心制作过。✊✊✊
⭐【学无止境小奇】的博客中所有涉及命令、代码的地方,除了提供图片供大家参考,另外会在图片下方提供一份纯文本格式的命令或者代码方便大家粘贴复制直接执行命令或者运行代码。🤝🤝🤝
⭐如果你对技术有着浓厚的兴趣,欢迎关注【学无止境小奇】,欢迎大家和我一起交流。😘😘😘
❤️❤️❤️感谢各位朋友接下来的阅读❤️❤️❤️
一、leetcode算法
1、二叉树的后序遍历
1.1、题目
给你一棵二叉树的根节点 root ,返回其节点值的 后序遍历 。
示例 1:
输入:root = [1,null,2,3]
输出:[3,2,1]
示例 2:
输入:root = []
输出:[]
示例 3:
输入:root = [1]
输出:[1]
1.2、思路
思路一:此题我们首先要知道何为二叉树的后序遍历:按照访问左子树-右子树-根节点的方式遍历这棵树,而在访问左子树或者右子数的时候,我们按照同样的方式遍历,直到遍历完整棵树。因此整个遍历过程天然具有递归的性质,我们可以直接用递归函数来模拟这一过程。
1.3、答案
class Solution {
public List<Integer> postorderTraversal(TreeNode root) {
List<Integer> res = new ArrayList<>();
postorder(root,res);
return res;
}
public void postorder(TreeNode root,List<Integer> res){
if(root == null){
return;
}
postorder(root.left,res);
postorder(root.right,res);
res.add(root.val);
}
}
复杂度分析
时间复杂度:O(n),其中 n 是二叉搜索树的节点数。每一个节点恰好被遍历一次。
空间复杂度:O(n),为递归过程中栈的开销,平均情况下为 O(logn),最坏情况下树呈现链状,为 O(n)。
相关文章
- 【Leetcode】102. 二叉树的层序遍历(中等)
- LeetCode 剑指offer 68【二叉树的最近公共祖先】
- LeetCode题解——700.二叉树搜索树中的搜索
- LeetCode 144. 二叉树的前序遍历
- LeetCode 94. 二叉树的中序遍历
- LeetCode | 二叉树高频面试算法题汇总【速来】
- 112、【树与二叉树】leetcode ——108. 将有序数组转换为二叉搜索树:二分查找树(C++版本)
- 102、【树与二叉树】leetcode ——654. 最大二叉树(C++版本)
- 90、【树与二叉树】leetcode ——104. 二叉树的最大深度:层次遍历+DFS+子问题分解(C++版本)
- 89、【树与二叉树】leetcode ——101. 对称二叉树:后序递归+迭代法+层次遍历(C++版本)
- 【leetcode】102:二叉树的层序遍历
- 【leetcode】106: 从中序与后序遍历序列构造二叉树
- [LeetCode] 1104. Path In Zigzag Labelled Binary Tree 之字形二叉树路径
- [LeetCode] 998. Maximum Binary Tree II 最大二叉树之二
- [LeetCode] 790. Domino and Tromino Tiling 多米诺和三格骨牌
- [LeetCode] 662. Maximum Width of Binary Tree 二叉树的最大宽度
- [LeetCode] 94. Binary Tree Inorder Traversal 二叉树的中序遍历
- [LeetCode] 102. Binary Tree Level Order Traversal 二叉树层序遍历
- leetcode 145. Binary Tree Postorder Traversal 二叉树的后序遍历 (中等)
- leetcode 144. Binary Tree Preorder Traversal 二叉树展开为链表(中等)
- leetcode 110. Balanced Binary Tree 平衡二叉树(简单)
- leetcode算法257.二叉树的所有路径