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

外包网站建设多少钱百度一下百度官网

外包网站建设多少钱,百度一下百度官网,海口网站建设公司排名,网站备案没通过不了目录 题目:剑指 Offer 54. 二叉搜索树的第k大节点 - 力扣(Leetcode) 题目的接口: 解题思路: 代码: 过啦!!! 题目:剑指 Offer 55 - I. 二叉树的深度 - 力…

目录

题目:剑指 Offer 54. 二叉搜索树的第k大节点 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过啦!!!

题目:剑指 Offer 55 - I. 二叉树的深度 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过啦!!!

题目:剑指 Offer 55 - II. 平衡二叉树 - 力扣(Leetcode)

题目的接口:

解题思路:

代码:

过啦!!!

写在最后:


题目:剑指 Offer 54. 二叉搜索树的第k大节点 - 力扣(Leetcode)

题目的接口:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:int kthLargest(TreeNode* root, int k) {}
};

解题思路:

因为平衡二叉树的特点是,走中序遍历是一个升序数组,

题目要求找出第k大的值,

那不难想到,我们只需要倒着中序遍历平衡二叉树就行,

每次让k--,只要k==0就表明找到了:

代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:int kthLargest(TreeNode* root, int k) {//走中序遍历dfs(root, k);return ans;}
private://记录k节点的值int ans = 0;//走一个倒序的中序遍历,让k值每走一个节点就--void dfs(TreeNode* root, int& k) {if(root == nullptr) return;dfs(root->right, k);//找到题目要求节点,记录ans值if(--k == 0) {ans = root->val;return;}dfs(root->left, k);}
};

过啦!!!

题目:剑指 Offer 55 - I. 二叉树的深度 - 力扣(Leetcode)

题目的接口:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:int maxDepth(TreeNode* root) {}
};

解题思路:

我的思路是,计算每一个子树的左右子树的深度,

然后比较每一个左右子树的深度,保存最大值,

具体解析如图所示:

 通过不断计算每个子树的最大深度,

最后得出整棵树的最大深度

下面是代码:

代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:int maxDepth(TreeNode* root) {if(root == nullptr) return 0;int left = maxDepth(root->left); //求出左边高度int right = maxDepth(root->right); //求出右边高度return max(left, right) + 1; //每层 + 1}
};

过啦!!!

题目:剑指 Offer 55 - II. 平衡二叉树 - 力扣(Leetcode)

题目的接口:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:bool isBalanced(TreeNode* root) {}
};

解题思路:

具体思路是,

我们通过计算左右子树的最大深度差,

如果左右子树的最大深度差 >= 2 证明不是平衡二叉树,

如果 < 2 就证明这个子树本身是平衡二叉树,那就正常计算自身的最大深度,

一直到根节点的左右子树依然没有返回 -1 深度符合要求,证明是平衡二叉树,

如果返回了 -1 就证明不是平衡二叉树,

这里计算最大深度的思想也沿用了上一题的思路,

下面是代码:

代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:bool isBalanced(TreeNode* root) {//判断如果返回-1就证明不是平衡二叉树return recur(root) != -1;}
private:int recur(TreeNode* root) {if(root == nullptr) return 0;//计算左右子树最大深度,如果出现-1证明不是平衡二叉树,返回-1就行int left = recur(root->left);if(left == -1) return -1;int right = recur(root->right);if(right == -1) return -1;//核心代码:如果左右子树最大深度正常,就正常计算左右深度的最大值//如果左右子树的最大深度差大于2,就证明这不是一个平衡二叉,返回-1return abs(left - right) < 2 ? max(left, right) + 1 : -1; }
};

过啦!!!

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果喜欢本文的话,欢迎点赞和评论,写下你的见解。

如果想和我一起学习编程,不妨点个关注,我们一起学习,一同成长。

之后我还会输出更多高质量内容,欢迎收看

http://www.hkea.cn/news/15204/

相关文章:

  • 外贸网站建设经验佛山营销型网站建设公司
  • 微商城网站建设推广qq群推广方法
  • 郑州做的比较好网站公司吗杭州seo 云优化科技
  • 高校网站建设方案新站如何让百度快速收录
  • 免费网站建设案例莆田seo推广公司
  • 做网页设计卖钱的网站优化网站平台
  • 邯郸网站建设中国有几个搜索引擎
  • 网站推广计划的内容百度关键词收费标准
  • 厦门建设局网站中标结果查询如何屏蔽百度广告推广
  • 自适应网站可以做伪静态页面吗友情链接的形式有哪些
  • 今日新开网站yandere搜索引擎入口
  • 哪个网站可以做ppt模板知识付费小程序搭建
  • 重庆网站推广解决方案百度关键词优化系统
  • 江西中恒建设集团有限公司网站高级搜索技巧
  • 免费b2b网站模板一个免费的网站
  • 整形美容网站源码最全的搜索引擎
  • 做网站怎么赚钱 111搜索引擎优化方法有哪几种
  • 2018年做网站赚钱免费发布软文广告推广平台
  • 潍坊网站优化公司世界大学排名
  • 网站建设与运营的预算方案模板免费大数据查询平台
  • google seo 营销网站小红书软文案例
  • 上海建网站方案seo教程视频论坛
  • 合肥网站设计哪家公司好百度seo权重
  • 企业网站优化是什么营销课程培训视频
  • 移动端网站怎么布局海南网站推广
  • 网站怎么开通微信支付百度app安装免费下载
  • 河北中石化建设网站在哪里找专业推广团队
  • 学广告专业我后悔了北京seo优化公司
  • 网站建设怎么谈品牌型网站制作价格
  • php网站建设案例雅虎搜索引擎首页