代码随想录 Day23 669. 修剪二叉搜索树 108.将有序数组转换为二叉搜索树 538.把二叉搜索树转换为累加树 总结篇

669. 修剪二叉搜索树 

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;}
};

思路:

1. 本题的思路是有些难想的,核心的思想依然是分情况进行讨论。如果说当比最小的值还要小的时候,就再看看它的右边有没有能够符合的。

2. 在区间中的情况就是让root->left = 递归... 这个地方有些疑问的是这一部分需不需要放在else里面???

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

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;}
};

问题:

1. 需要使用&,因为如果是不使用引用的话就会出现每次在使用的时候都会对于数组元素进行复制,如果使用了引用就只是传递一个地址这样的话就可以提高效率。

2. 凡是进行递归都一定要记得在最开始的位置处填写递归的终止情况,像是在本题中想要搞清楚终止条件就需要知道左右区间的关系问题究竟是左闭右开的还是左闭右闭的,如果是像本题中的情况一样就是左闭右闭的情况,终止条件就应该是left>right。而不是left>=right。

3. 因为是一颗树所以说使用root->left=....。并且在返回的时候是返回该节点,而不是返回root->left.这样的话最终才能构成一棵二叉树。

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

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;}
};
class Solution {
public:TreeNode* pre = NULL;TreeNode* convertBST(TreeNode* root) {if(root == NULL) return root;root->right = convertBST(root->right);if(pre != NULL) root->val += pre->val;pre = root;root->left = convertBST(root->left);return root;}
};

思路:

1. 按照卡哥的说法来讲,如果这个地方是一个数组的话,那么本题就是非常简单的,因为我们只需要将数组从后向前遍历累加就可以了。所以说这个问题难就难在它是一个二叉树,对于二叉树中序的倒遍历是有难度的。

2. 这个地方卡哥的做法是将pre设置成一个int型的数,这个地方也可以直接使用节点,但是使用节点的话就需要注意,有可能存在节点为NULL的情况的异常,为了避免出现这种情况的异常,就需要在使用这个节点以前先进行判断,当不是NULL的时候才可以使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/783989.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

li标签间的空白问题解决

li 与 li 之间有看不见的空白间隔是什么原因引起的&#xff1f; 浏览器会把inline内联元素间的空白字符&#xff08;空格、换行、Tab等&#xff09;渲染成一个空格。为了美观&#xff0c;通常是一个<li>放在一行&#xff0c;这导致<li>换行后产生换行字符&#xf…

详解CAS(Compare and swap)

一、什么是 CAS CAS: 全称Compare and swap&#xff0c;字⾯意思:”⽐较并交换“&#xff0c;⼀个 CAS 涉及到以下操作&#xff1a; 我们假设内存中的原数据V&#xff0c;旧的预期值A&#xff0c;需要修改的新值B。 比较 A 与 V 是否相等。&#xff08;⽐较&#xff09; 如果…

日志集中审计系列(3)--- LogAuditor接收UMA设备syslog日志

日志集中审计系列(3)--- LogAuditor接收UMA设备日志 前言拓扑图设备选型组网需求配置思路操作步骤结果验证前言 近期有读者留言:“因华为数通模拟器仅能支持USG6000V的防火墙,无法支持别的安全产品,导致很多网络安全的方案和产品功能无法模拟练习,是否有真机操作的实验或…

PyCharm中出现Microsoft Defender配置建议

原因 Windows安全中心的病毒和威胁防护会自动扫描电脑中的文件夹&#xff0c;我们的项目文件夹和IDE文件夹也会被扫描&#xff0c;而PyCharm认为这会降低IDE性能。 解决方法 直接点击提示框里的自动。 或是手动给扫描添加排除项&#xff0c;步骤如下&#xff1a; 1、先打开…

k8s1.28.8版本配置Alertmanager报警方式(邮件,企业微信)

文章目录 总结部署流程 Alertmanager 三大核心1. 分组告警2. 告警抑制3. 告警静默 报警过滤静默通知方案一&#xff1a;方案二&#xff1a; 抑制报警规则案例一 参考文档 自定义路由告警&#xff0c;分来自不同路由的告警&#xff0c;艾特不同的人员进行区分修改 alertmanager …

预训练大模型最佳Llama开源社区中文版Llama2

Llama中文社区率先完成了国内首个真正意义上的中文版Llama2-13B大模型&#xff0c;从模型底层实现了Llama2中文能力的大幅优化和提升。毋庸置疑&#xff0c;中文版Llama2一经发布将开启国内大模型新时代。 作为AI领域最强大的开源大模型&#xff0c;Llama2基于2万亿token数据预…

【C++入门】输入输出、命名空间、缺省参数、函数重载、引用、内联函数、auto、基于范围的for循环

目录 命名空间 命名空间的定义 命名空间的使用 输入输出 缺省参数 函数重载 引用 常引用 引用的使用场景 内联函数 auto 基于范围的for循环 命名空间 请看一段C语言的代码&#xff1a; #include <stdio.h> #include <stdlib.h>int rand 10;int main…

java打家劫舍 1 (力扣Leetcode 198)

打家劫舍 1 力扣原题链接 问题描述 你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报…

修改aws账户的密码和MFA

要使用AWS CLI删除当前账户的多因素认证(MFA)设备并修改密码&#xff0c;你需要先确保已安装并配置了AWS CLI&#xff0c;并且你的账户有足够的权限执行这些操作。下面是如何分步进行的指导&#xff1a; 1. 删除MFA设备 首先&#xff0c;你需要找出MFA设备的序列号或ARN。可以…

《堕落的审判》吵架台词

一个人没有做某件事的原因就是这个人没有做这件事&#xff0c;与其他任何原因没有关系。所有的原因都是找理由&#xff0c;都是替罪的羔羊&#xff0c;都是自我麻醉的毒药&#xff0c;都是在饮鸩止渴。 愤怒的本质就是对自我无能的控诉。 (Sandra)-What do you expect me to do…

图论-最短路

一、不存在负权边-dijkstra算法 dijkstra算法适用于这样一类问题&#xff1a; 从起点 start 到所有其他节点的最短路径。 其实求解最短路径最暴力的方法就是使用bfs广搜一下&#xff0c;但是要一次求得所有点的最短距离我们不可能循环n次&#xff0c;这样复杂度太高&#xf…

Docker + Nginx 安装

安装Docker 1.防火墙 2.yum源 3.安装基础软件 更新yum源 wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo yum clean all #清除yum源缓存 yu…

【JavaScript编程】forEach跳出循环

在JavaScript中&#xff0c;forEach函数用于遍历数组中的每一个元素&#xff0c;并对每个元素执行一次回调函数。然而&#xff0c;forEach函数并没有内置的方法可以直接跳出整个循环&#xff0c;因为它设计之初就是为了确保每个元素都会被处理。但是&#xff0c;你可以通过一些…

每天学习python30分钟(第二天)

1.字典&#xff1a; 相当与数据结构 定义与访问 tinydict {Name: Zara, Age: 7, Class: First}print("tinydict[Name]: ", tinydict[Name]) print("tinydict[Age]: ", tinydict[Age]) tinydict[Name]: Zara tinydict[Age]: 7 也可以 tinydict1 { …

推挽输出与开漏输出

推挽输出与开漏输出 文章目录 推挽输出与开漏输出前言一、推挽输出二、开漏输出总结 前言 在使用GPIO口时&#xff0c;会遇到两种配置&#xff0c;一种叫推挽输出&#xff0c;一种叫开漏输出&#xff0c;今天就简聊一聊这两种模式的差异和选择。 一、推挽输出 如图所示&#…

力扣 1035. 不相交的线

题目来源&#xff1a;https://leetcode.cn/problems/uncrossed-lines/description/ C题解&#xff1a;经过细细一推导&#xff0c;就发现跟力扣 1143. 最长公共子序列-CSDN博客 换汤不换药。 直线不能相交&#xff0c;说明元素顺序不能改变&#xff0c;求可以绘制的最大连线数…

【数据结构与算法】二叉树遍历、判断和 diff 算法

遍历 深度优先遍历 function Node(value) {this.value valuethis.left nullthis.right null }let a new Node(a) let b new Node(b) let c new Node(c) let d new Node(d) let e new Node(e) let f new Node(f) let g new Node(g) a.left c a.right b c.l…

2024年3月29日西山居游戏运维开发面经

1&#xff0c;请做一下自我介绍吧&#xff08;简短的说了一下自己的情况&#xff0c;包括姓名&#xff0c;教育情况&#xff0c;来自什么地方&#xff09; 2&#xff0c;你刚有提到《尘白禁区》&#xff0c;你从开服就玩的吗&#xff1f; 3&#xff0c;你的简历上有写k8s&…

【Linux的进程篇章 - 冯诺依曼的体系结构】

Linux学习笔记---005 Linux冯诺依曼体系结构理解1、冯诺依曼体系结构1.1、冯诺依曼体系结构1.2、硬件层面1.3、数据层面1.4、那么冯诺依曼体系能干什么呢&#xff1f; 2、操作系统(Operastor System)2.1、概念2.2、操作系统层的核心功能 3、进程的初步理解 Linux冯诺依曼体系结…

动态规划-最长回文子串

动态规划-最长回文子串 原题描述解答中心移动思想代码实现复杂度分析时间复杂度空间复杂度 动态规划思想代码实现复杂度分析时间复杂度空间复杂度 突然觉得很有必要将学过的内容记录下来&#xff0c;这样后续在需要用到的时候就可以避免从头进行学习&#xff0c;而去看自己之前…