LeetCode中如何翻转二叉树
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章主要介绍LeetCode中如何翻转二叉树,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!题目描述:翻转一棵二叉树。示例:输入:输出:思路分析:通过观察,我们发现只要把二叉
千家信息网最后更新 2025年02月03日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安全错误
数据库的锁怎样保障安全
通信网络技术知识点
怎样找回应用数据库
唐家岭租房软件开发
网络安全是为了网络数据
大学生网络安全知识题目
fuseki数据库
网络安全危害事件案例
ecshop软件开发环境
服务器海豚卡配件
数据库实时同步时延指标
数据库sql语句嵌套判断
搞网络安全好还是软件开发好
黑魂三要登录服务器吗
ibm服务器显示器
薄荷网络技术简历
创建php数据库
软件开发工程量计算
软件开发公司的联系电话
社区网络安全检查
regrna20数据库
纪委办公室网络安全责任制
c 数据库api
网络安全3个红线
瑞庭网络技术上海有限公司客服
中央网络安全信息主任
数据库date报错4220
客户 服务器方式
网络安全运维工作规划
禹城市网络安全宣传图片
神奇屋网络技术服务