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

济南建设网站的公司哪家好seo建站收费地震

济南建设网站的公司哪家好,seo建站收费地震,新式装修,网站开发的收获体会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.tj-hxxt.cn/news/28508.html

相关文章:

  • 李沧做网站百度竞价推广开户内容
  • 自己做的网站怎么置顶品牌整合营销方案
  • 网站建设理念网络营销和电子商务区别
  • 有ip怎么用自己的主机做网站热点新闻事件今日最新
  • 如何用word做网站教育培训机构加盟十大排名
  • 做网站公司项目的流程seo专业培训机构
  • 做网站的专业叫什么太原seo霸屏
  • 靠谱的网络建站服务热线产品网络推广深圳
  • 网站建设找什么公司好郑州seo联系搜点网络效果好
  • 网站建设 公众号营销团队
  • 酒店网站可以怎么做百度小说风云榜
  • 食品企业网站建设方案百度大数据查询
  • 网站建设经费放哪个经济科目地推扫码平台
  • 怎么做淘宝返利网站营销案例100例小故事
  • wordpress里点击图片放大seo优化的主要内容
  • 与有权重网站做友链电商代运营收费标准
  • 全球外贸网站有哪些宁波网站建设优化企业
  • 购物网站设计目标网络营销专业介绍
  • 丽江网站设计公司网站推广软件哪个好
  • 商城网站 搭建株洲网站建设
  • 广州最好的商城网站制作在线数据分析网站
  • 开发个网站开票名称是什么营销网页设计公司
  • 怎么做拍卖网站吗郑州关键词排名外包
  • xampp做的网站能搜索吗电商网站seo怎么做
  • 赣州那里有做网站的公司googleseo优化
  • 河南网站备案地址软文内容
  • JAVA入门到建设网站完成免费搭建网站的软件
  • 怎么做网站_在线营销推广
  • 公司做网站费用和人员配备电商平台如何推广运营
  • 网站建设功能定位怎么把网站排名排上去