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

上蔡做网站如何优化培训体系

上蔡做网站,如何优化培训体系,做下载网站用什么程序好,给别人做网站没做完算诈骗吗非科班学习算法day21 | LeetCode669:修剪二叉搜索树 ,Leetcode108:将有序数组转换为二叉搜索树 ,Leetcode538:把二叉搜索树转换为累加树 介绍 包含LC的两道题目,还有相应概念的补充。 相关图解和更多版本: 代码随想录 (progra…

非科班学习算法day21 | LeetCode669:修剪二叉搜索树 ,Leetcode108:将有序数组转换为二叉搜索树 ,Leetcode538:把二叉搜索树转换为累加树 


介绍

包含LC的两道题目,还有相应概念的补充。

相关图解和更多版本:

代码随想录 (programmercarl.com)https://programmercarl.com/#%E6%9C%AC%E7%AB%99%E8%83%8C%E6%99%AF


二、LeetCode题目

1.LeetCode669:修剪二叉搜索树 

题目链接:669. 修剪二叉搜索树 - 力扣(LeetCode)

题目解析

       这道题第二次做一开始还是迷糊,其实本质还是删除节点,只不过我们需要直到,不能看到没在范围的就直接删除,因为其子树也是有大有小的,所以就要处理相应的节点。那就是在下限之下,向右边遍历;在上限之上,向左边遍历。同时对于节点的拼接处理就是去掉一半子树。思路想清楚代码看起来还是比较简洁。

 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* trimBST(TreeNode* root, int low, int high) {if(!root) return nullptr;if(root->val<low){return trimBST(root->right, low,high);}if(root->val >high){return trimBST(root->left,low,high);}root->left = trimBST(root->left,low,high);root->right = trimBST(root->right,low,high);return root;}
};

 2.Leetcode108:将有序数组转换为二叉搜索树 

题目链接:108. 将有序数组转换为二叉搜索树 - 力扣(LeetCode)

题目解析

        一开始还在想是不是需要将奇偶分类,实际上没有必要,因为有平衡的要求也不用慌,因为最中间的两个值,用左边和右边构造是一样的。这里就采用中间左边构造的形式。

        需要理清思路:每层选取最中间的数作为根节点,有点像之前根据遍历顺序构造数的做法。想清楚这个之后,代码才能好写起来。

 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* sorted(vector<int>& nums, int left, int right) {if(left>right) return nullptr;int mid = left + (right - left) / 2;TreeNode* root = new TreeNode(nums[mid]);root->left = sorted(nums, left, mid - 1);root->right = sorted(nums, mid + 1, right);return root;}TreeNode* sortedArrayToBST(vector<int>& nums) {return sorted(nums, 0, nums.size() - 1);}
};

 注意点:因为要整个遍历,且返回值是作为对应根节点的孩子节点接住的!所以直接用root->left

3.Leetcode538:把二叉搜索树转换为累加树

题目链接:538. 把二叉搜索树转换为累加树 - 力扣(LeetCode)

题目解析

          一眼看上去也是构造树,不过这道题不需要动节点,只需要返回节点的值进行运算就可以,这里也是用回溯的思想。先遍历右边将右边的值返回,中做处理,就是相加,最后遍历左边。这样就符合了累加树的计算方法     

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:// 尝试右中左遍历int sum = 0;TreeNode* convertBST(TreeNode* root) {if (!root)return nullptr;convertBST(root->right);sum += root->val;root->val = sum;convertBST(root->left);return root;}
};

注意点1:只是提供了一种新的思路,面对二叉树要灵活,把已经做过的看看能不能用上。

 

总结


补打卡第21天,坚持!!!

http://www.mmbaike.com/news/111674.html

相关文章:

  • 全国工程信息查询平台seo标签优化
  • 做数据权威的网站搜狗官方网站
  • 2019年的阜南县建设修路网站百度竞价排名规则及费用
  • 网站app开发哪家好最好的网络推广方式
  • 服装网站建设策划书的基本结构站长素材网
  • 千图网免费海报素材图库常见的系统优化软件
  • 网站建设团队武汉如何做网页设计
  • 全国建设部网站证书查询上海疫情突然消失的原因
  • 本科专业建设规划西安seo代运营
  • 怎样建设小游戏网站seo快速排名软件网站
  • 手机网站建设ppt昆明seo
  • 移动商城型网站开发产品软文范例
  • 织梦cms手机网站源码深圳搜索引擎优化推广
  • 佛山h5网站公司软文技巧
  • 那种登录才能查看的网站怎么做优化自己的网站怎么样推广优化
  • 温州做阀门网站公司百度竞价代理商
  • 网站建设发展情况搜狗官网
  • 怎么做自己独立的网站济南做网站公司哪家好
  • 广西南宁建设厅网站嘉兴seo计费管理
  • 大同市政府门户网站站长之家ip地址归属查询
  • 网站建设的能力大概需要多少钱
  • 网站建设学习网微信小程序开发费用一览表
  • 企业网站写好如何发布会计培训班要多少钱一般要学多久
  • 企业网站建设御彩云百度关键词挖掘查排名工具
  • 电脑哪里做ppt下载网站市场营销方案范文
  • 淘宝优惠券网站用什么软件做网站建设制作模板
  • 做网站交钱后以后还要教吗开封网站seo
  • 一个域名可以建设几个网站网络营销试卷
  • 本地如何搭建多个网站做测试创建网站的基本流程
  • 网络营销策划ppt范例沈阳关键词优化价格