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

湛江网站建设策划方案祖传做网站

湛江网站建设策划方案,祖传做网站,如何自己动手做网站,阿里云建设wordpress目录 LeetCode: 669. 修剪二叉搜索树 基本思路 C代码 LeetCode: 108.将有序数组转换为二叉搜索树 基本思路 C代码 LeetCode: 538.把二叉搜索树转换为累加树 基本思路 C代码 LeetCode: 669. 修剪二叉搜索树 力扣代码链接 文字讲解:LeetCode: 669. 修剪二叉搜…

目录

LeetCode: 669. 修剪二叉搜索树

基本思路

C++代码

LeetCode: 108.将有序数组转换为二叉搜索树

基本思路

C++代码

LeetCode: 538.把二叉搜索树转换为累加树

基本思路

C++代码


LeetCode: 669. 修剪二叉搜索树

力扣代码链接

文字讲解:LeetCode: 669. 修剪二叉搜索树

视频讲解:你修剪的方式不对,我来给你纠正一下!

基本思路

        这个题目比较简单,但是一定要注意遇到节点在目标区间以外,不能直接返回null,而是应该继续向下判定,因为对于一个搜索二叉树来讲,在遍历整个二叉树的节点的过程中,如果某个节点的值小于区间的最小值,对于该节点的左子树中的所有节点一定都小于目标区间的最小值,但是右子树中却可能存在符合目标区间的值,因此还需要进一步进行判定。

  • 确定递归函数的参数以及返回值

        参数:需要传入当前遍历的节点,还需要传入目标取件的边界值low和high。

        返回值:返回需要删除的节点。

TreeNode* trimBST(TreeNode* root, int low, int high)
  • 确定终止条件

        修剪的操作并不是在终止条件上进行的,所以就是遇到空节点返回就可以了。

if (root == nullptr ) return nullptr;
  • 确定单层递归的逻辑

        如果root(当前节点)的元素小于low的数值,那么应该递归右子树,并返回右子树符合条件的头结点。

if (root->val < low) {TreeNode* right = trimBST(root->right, low, high); // 寻找符合区间[low, high]的节点return right;
}

        如果root(当前节点)的元素大于high的,那么应该递归左子树,并返回左子树符合条件的头结点。

if (root->val > high) {TreeNode* left = trimBST(root->left, low, high); // 寻找符合区间[low, high]的节点return left;
}

        接下来要将下一层处理完左子树的结果赋给root->left,处理完右子树的结果赋给root->right。

root->left = trimBST(root->left, low, high); // root->left接入符合条件的左孩子
root->right = trimBST(root->right, low, high); // root->right接入符合条件的右孩子
return root;

C++代码

class Solution {
public:TreeNode* trimBST(TreeNode* root, int low, int high) {if (root == nullptr ) return nullptr;if (root->val < low) {TreeNode* right = trimBST(root->right, low, high); // 寻找符合区间[low, high]的节点return right;}if (root->val > high) {TreeNode* left = trimBST(root->left, low, high); // 寻找符合区间[low, high]的节点return left;}root->left = trimBST(root->left, low, high); // root->left接入符合条件的左孩子root->right = trimBST(root->right, low, high); // root->right接入符合条件的右孩子return root;}
};

LeetCode: 108.将有序数组转换为二叉搜索树

力扣代码链接

文字讲解:LeetCode: 108.将有序数组转换为二叉搜索树

视频讲解:构造平衡二叉搜索树!

基本思路

        构建平衡二叉树是为因为给定任意一个有序数组,都可以直接构建一颗线性结构的二叉树。而构建二叉树我们首先就应该想到根据数组构建二叉树,本质就是寻找分割点,分割点作为当前节点,然后递归左区间和右区间分割点就是数组中间位置的节点。

  • 确定递归函数返回值及其参数

        参数:需要传入一个有序数组,并且需要传入数组的左右下标(根据数组的左右下标来构建二叉树)

        返回值:返回构建二叉树的根节点。

// 左闭右闭区间[left, right]
TreeNode* traversal(vector<int>& nums, int left, int right)

        这里注意,我这里定义的是左闭右闭区间,在不断分割的过程中,也会坚持左闭右闭的区间,这又涉及到我们讲过的循环不变量原则

  • 确定递归终止条件

        这里定义的是左闭右闭的区间,所以当区间left>right当时候,就是空结点了。

if (left > right) return nullptr;
  • 确定单层递归的逻辑

        根据数组区间的左右下标来构建二叉树,其中二叉树的根节点为mid = left+(right-left)/2,此时中间节点为:

TreeNode* root = new TreeNode(nums[mid]);

        接着划分区间,root的左孩子接住下一层左区间的构造节点,右孩子接住下一层右区间构造的节点,最后返回root节点。

int mid = left + ((right - left) / 2);//为偶数时向下取整
TreeNode* root = new TreeNode(nums[mid]);
root->left = traversal(nums, left, mid - 1);
root->right = traversal(nums, mid + 1, right);
return root;

C++代码

class Solution {
private:TreeNode* traversal(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 = traversal(nums, left, mid - 1);root->right = traversal(nums, mid + 1, right);return root;}
public:TreeNode* sortedArrayToBST(vector<int>& nums) {TreeNode* root = traversal(nums, 0, nums.size() - 1);return root;}
};

        注意:在调用traversal的时候传入的left和right为什么是0和nums.size() - 1,因为定义的区间为左闭右闭

LeetCode: 538.把二叉搜索树转换为累加树

力扣代码链接

文字讲解:LeetCode: 538.把二叉搜索树转换为累加树

视频讲解:普大喜奔!二叉树章节已全部更完啦!

基本思路

        其实这就是一棵树,大家可能看起来有点别扭,换一个角度来看,这就是一个有序数组[2, 5, 13],求从后到前的累加数组,也就是[20, 18, 13],是不是感觉这就简单了。

        为什么变成数组就是感觉简单了呢?

        因为数组大家都知道怎么遍历啊,从后向前,挨个累加就完事了,这换成了二叉搜索树,看起来就别扭了一些是不是。那么知道如何遍历这个二叉树,也就迎刃而解了,从树中可以看出累加的顺序是右中左,所以我们需要反中序遍历这个二叉树,然后顺序累加就可以了。

  • 递归函数参数以及返回值

        首先需要定义一个全局变量pre,用来记录前一个节点的值。

        参数:传入当前节点

        返回值:只需要对遍历的节点的值进行操作,不需要什么返回值。

int pre = 0; // 记录前一个节点的数值
void traversal(TreeNode* cur)
  • 确定终止条件

        遇空节点就终止。

if (cur == NULL) return;
  • 确定单层递归的逻辑

        注意要右中左来遍历二叉树, 中节点的处理逻辑就是让cur的数值加上前一个节点的数值。

traversal(cur->right);  // 右
cur->val += pre;        // 中
pre = cur->val;
traversal(cur->left);   // 左

C++代码

class Solution {
private:int pre = 0; // 记录前一个节点的数值void traversal(TreeNode* cur) { // 右中左遍历if (cur == NULL) return;traversal(cur->right);cur->val += pre;pre = cur->val;traversal(cur->left);}
public:TreeNode* convertBST(TreeNode* root) {pre = 0;traversal(root);return root;}
};
http://www.yayakq.cn/news/805718/

相关文章:

  • WordPress搭建流媒体网站建阳网站建设wzjseo
  • 百度上网站怎么做wordpress分类页面空白
  • 建个什么网站好呢网站论坛推广方案
  • 廊坊seo整站优化软件archdaily
  • 建设一个网站用什么搭建大流量网站建设
  • 国外的网站可以做百度推广吗淘宝类网站开发
  • 做网站需要网络服务器紫色的网站
  • 深圳营销型网站建设公司选择哪家好普通的宣传网站用什么做
  • 江门网站建设联系电话展示型网站
  • wordpress用了cdn和缓存插件官方网站建设优化
  • 网站名称跟域名广州海珠网站开发定制
  • 网站建设需要做什么昆明做整站优化
  • led网站免费模板佛山企业网站开发公司
  • 查看企业信息的网站网络规划与设计报告
  • 做网站公司工资wordpress对话框模板
  • 河南网站建设推广公司wordpress 怎么删除主题
  • 安徽建设工程信息网官方网站如何找客户资源
  • 昆山高端网站建设开发商贸公司经营范围
  • 法律网站模板源码分享
  • 肇庆有哪家做企业网站的wordpress文章推送到微信
  • 网站编辑给续南明做的封面百度推广 帮做网站吗
  • 58同城网站建设推广网站建设豌豆荚app下载 官网
  • 东莞网站建设企业seo服务建议
  • 虎嗅wordpress模板seo的方法有哪些
  • 如何增加网站访问量网站建设意义必要性
  • 南通免费建设网站wordpress模板 门户网站
  • 景区网站做电子商务的特点百度seo关键词优化电话
  • 网站还需要备案么公众号同步到dede网站
  • 网站建设 考核指标wordpress小程序收录
  • 搭建网站的大致流程企业网站制作方案