当前位置: 首页 > news >正文

域名cn是个什么网站wordpress编辑分段

域名cn是个什么网站,wordpress编辑分段,一流的福州网站建设,桐乡网站设计226. 翻转二叉树 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1] 示例 2: 输入:root [2,1,3] 输出:[…

226. 翻转二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

示例 1:

在这里插入图片描述

输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]

示例 2:

在这里插入图片描述

输入:root = [2,1,3]
输出:[2,3,1]

示例 3:

输入:root = []
输出:[]

提示:

  • 树中节点数目范围在 [0, 100] 内
  • -100 <= Node.val <= 100

思路:递归

这是一道很经典的二叉树问题:

  • 我们从根节点开始,递归地对树进行遍历,并从叶子节点先开始翻转。
  • 如果当前遍历到的节点 root 的左右两棵子树都已经翻转,那么我们只需要交换两棵子树的位置
  • 从而完成以 root为根节点的整棵子树的翻转。

代码:(Java、C++)

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 tem = invertTree(root.left);root.left = invertTree(root.right);root.right = tem;return root;}
}

C++

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:TreeNode* invertTree(TreeNode* root) {if(root == NULL) return root;TreeNode* tem = invertTree(root->left);root->left = invertTree(root->right);root->right = tem;return root;}
};

运行结果:

在这里插入图片描述

复杂度分析:

  • 时间复杂度O(n)O(n)O(n),其中n 为二叉树节点的数目。我们会遍历二叉树中的每一个节点,对每个节点而言,我们在常数时间内交换其两棵子树。
  • 空间复杂度O(height)O(height)O(height)。使用的空间由递归栈的深度决定,它等于当前节点在二叉树中的高度。在平均情况下,二叉树的高度与节点个数为对数关系,即 O(n)O(n)O(n)。而在最坏情况下,树形成链状,空间复杂度为 O(n)O(n)O(n)

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我 leetCode专栏,每日更新!

注: 如有不足,欢迎指正!

http://www.yayakq.cn/news/84028/

相关文章:

  • 北京网站制作公司兴田德润可信赖内江市建设培训中心网站
  • 海口网站建设哪家好动漫设计与制作主修课程
  • 网站建设成都云网站建设的一些原理
  • 网站建设沈阳凯鸿软文营销写作技巧
  • 做高端品牌网站网站开发网页gif设计公司
  • 青岛网站建设优化医院网站建设报价表
  • 公司网站建设设计服务seo网站建设时文章频率
  • wordpress网站没有阅读量app研发风险
  • 上海网站建设与设计快速网站收录
  • 瓯北网站制作wordpress dante
  • 旅游网站模块福州工程建设信息网站
  • 网站建设是干什么的网站地图链接怎么做
  • 网站更换ico文件位置新乡seo顾问
  • 中国建设报官方网站怎么去掉wordpress底部
  • 做网站没有数据商城网站建设 上海
  • 滨州做微商城网站广东阳江房产网
  • 建站仅向商家提供技术服务网店代运营收费多少钱
  • 郴州网站建设公司电话wordpress pdf 免费下载
  • 大连宏帝建设网站wordpress退出代码
  • 成都APP 微网站开发东莞有哪些公司
  • 网站开发外包一个wordpress noindex
  • 建设银行个人网站个人客户python设计模式
  • 县区网站建设运行汇报建设网站的报告
  • 烟台牟平住房建设局网站三桥网站建设
  • 网站并发要求湖南长沙公司有哪些
  • 手机网站北京网站建设信息科技公司
  • 网站设计师需要学什么wordpress心情插件
  • 建立网站的信息集成过程江苏省建设厅网站查询
  • 网站建设项目采购合同建设一个购物网站需要多少钱
  • 网站建设的系统分析信阳有什么推广平台