LeetCode中如何翻转二叉树
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,这篇文章主要介绍LeetCode中如何翻转二叉树,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目描述:翻转一棵二叉树。示例:输入:输出:思路分析:通过观察,我们发现只要把二叉
千家信息网最后更新 2025年12月04日LeetCode中如何翻转二叉树
这篇文章主要介绍LeetCode中如何翻转二叉树,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
题目描述:
翻转一棵二叉树。
示例:
输入:
输出:
思路分析:
通过观察,我们发现只要把二叉树上的每一个节点的左右子节点进行交换,最后的结果就是完全翻转之后的二叉树。
这道题目比较简单,关键思路在于我们发现翻转整棵树就是交换每个节点的左右子节点,于是我们把交换左右子节点的代码放在了前序遍历的位置。
值得一提的是,如果把交换左右子节点的代码放在后序遍历的位置也是可以的,但是放在中序遍历的位置是不行的。
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 TreeNode invertTree(TreeNode root) {
if(root==null){
return root;
}
TreeNode tmp=root.left;
root.left=root.right;
root.right=tmp;
invertTree(root.left);
invertTree(root.right);
return root;
}
}
Python实现
class Solution:
def invertTree(self, root: TreeNode) -> TreeNode:
if not root:
return root
left = self.invertTree(root.left)
right = self.invertTree(root.right)
root.left, root.right = right, left
return root
以上是"LeetCode中如何翻转二叉树"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!
节点
位置
代码
内容
就是
思路
篇文章
题目
不行
值得一提
价值
关键
兴趣
小伙
小伙伴
更多
知识
示例
结果
行业
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
从事网络技术
本三软件开发
msn 邮箱服务器
奥克兰软件开发有乡少公司
科技互联网十强
软件开发无基础公司
游戏软件开发项目的计划书
刑警网络技术
鲸钱包服务器崩溃
山西云服务器租用公司
方舟单机获得的皮肤服务器上有吗
云服务器管理期末考试
网络安全意识及网络安全理念
昆明软件开发多少钱
成都勤诚服务器
网络安全漏洞 两会
web和数据库安全
中国典型城市数据库
建立完善的费用档案系统和数据库
杨浦区信息软件开发信息中心
长沙思成网络技术有限公司
手机评测数据库小程序
一台服务器能用多少docker
飞腾排版软件开发
电子商务专业网络技术支持
如何防范网络安全威胁和风险
北京安卓智能软件开发公司
公安网计算机网络安全试题
潍坊化工管理软件开发
数据库用的表格数据