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

重庆李家沱网站建设互联网推广招聘

重庆李家沱网站建设,互联网推广招聘,营销策略的概念和内容,购物网站开发jdk226. 翻转二叉树 给你一棵二叉树的根节点 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.yidumall.com/news/45227.html

相关文章:

  • 基础建设文本网站如何提交百度收录
  • 做网站推广好做吗seo关键字优化
  • php建设动态网站网店代运营合同
  • 做化妆招生宣传在那些网站可以做广东seo推广哪里好
  • 西三旗网站建设东莞网站seo公司哪家大
  • 阜阳做网站哪家好搜索量查询
  • 软件测试培训一般多少钱深圳网站快速排名优化
  • 哪个网站能找到做夜场的女孩外链工厂
  • 电子商务网站建设推广分析高清网站推广免费下载
  • 做公司网站注意什么微信公众号的推广
  • 办个人网站租空间百度关键词查询工具
  • 随州网站建设哪家优惠北京建公司网站价格
  • 南京做网站南京乐识好白酒最有效的推广方式
  • 网站建设 价格百度链接地址
  • 交友app网站建设新站整站快速排名
  • 济南网站推广排名有网站模板怎么建站
  • wordpress 中表格 宽度seo关键词优化外包
  • adobe dreamweaver手机版搜索引擎优化的定义
  • 建设网站了还能消除吗培训方案怎么做
  • 网站图片360度旋转怎么做的seo工具网站
  • 杜桥做网站哪家好别做网络推广员
  • 企业建设好一个网站后_如何进行网站推广?买域名要多少钱一个
  • 商标查询网站怎么做西地那非片的功能主治和副作用
  • 上海招聘网站建设郑州seo团队
  • 手机app微信网站建设网络优化工程师吃香吗
  • 做网站云服务器选择多大带宽全网搜索引擎
  • 培训机构网站制作域名解析ip地址
  • 企业怎样选择域名做网站免费建站系统哪个好用吗
  • 深圳宝安区什么时候解封广州seo
  • 怎么免费弄网站口碑营销的优势