代碼隨想录 day22|day23

二叉树(完)

二叉搜索树的最近公共祖先
题意:找到二叉树的两个节点的祖先节点 。
思路: 二叉树的中序遍历特性: 如果当前遍历的节点的值> 两个指定的节点的值。 那么祖先节点就在当前节点左子树 。 如果当前遍历节点的值< 两个节点的值 则祖先节点在节点右边。 如果都不是那么当前节点是祖先节点。
核心代码

  TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {if(root->val >p->val && root->val > q->val){return   lowestCommonAncestor(root->left, p, q) ;// 利用搜索二叉树的性质:如果节点在左右节点之间,就是公共祖先。}else if(root->val < p->val && root->val < q->val){return lowestCommonAncestor(root->right, p, q);}return root ; }

二叉搜索树中的插入操作

题意: 是把一个值插入到二叉搜索树中;
思路:最简单的办法是将值插入到叶子结点的左边或者右边。 所以递归边界是节点的左右子树都是空,还有节点有左子树的但是右子树为空的情况。还有节点左子树为空,右子树不为空的情况。
思路2: 不改变二叉树的结构直接在叶子节点接住生成的节点。 通过当前root->val > val 就向左遍历。

class Solution {
public:TreeNode* insertIntoBST(TreeNode* root, int val) {if (root == NULL) {TreeNode* node = new TreeNode(val);return node;}if (root->val > val) root->left = insertIntoBST(root->left, val);if (root->val < val) root->right = insertIntoBST(root->right, val);return root;}
};

删除二叉搜索树中的节点

题意: 在找到相应值之后如果左或者右孩子有一个不空直接删除 ; 然后将其子返回即可。
但是在删除左右孩子都不为空的情况下,就需要将节点的左孩子直接赋给,右子树的最左叶子节点。 然后返回右子树的根节点。 这是根据二叉搜索树的性质来的。
核心代码

 TreeNode* deleteNode(TreeNode* root, int key) {if( root && root->val == key  ){if ( root->left != nullptr && root->right != nullptr) {// 因为左子树的节点都小于根节点的值,右子树的节点都大于根节点的值 // 将右子树的最左叶子节点,的左节点 的左边接上要删除的节点的右子树根节点。 TreeNode* tmp = root->right ;while(tmp->left){tmp = tmp->left ;} tmp->left =  root->left ;return root->right ; }else if(root->left == nullptr && root ->right != nullptr){TreeNode* tmp = root ; // delete tmp ; return root->right ; }else if(root->left != nullptr && root->right == nullptr){TreeNode* tmp = root ; // delete tmp ; return root->left ; }else{return nullptr ; }}if(root && root->val > key) root->left = deleteNode(root->left,key) ;if(root && root->val < key){root->right = deleteNode(root->right , key) ; }return root ; }

修剪二叉搜索树
虽然说着挺难,但是其实就是把删除二叉树的结点应用而已。
如果找到了不在范围的节点删除而已。
至于删除要分有左子节点没有右子节点的,有右子节点没有左子节点的。 和左右子节点都没有的。 另外需要从下往上回溯删除。不然就上一层的递归就接不着
核心代码

TreeNode* trimBST(TreeNode* root, int low, int high){if(root == nullptr){return nullptr ; }if(root && root->left ){root->left = trimBST(root->left , low ,high) ; }if(root && root->right ){root->right = trimBST(root->right , low ,high) ; }if(root->val <  low||root->val >  high) // 从下往上回溯,因为是从下往上处理的。 {cout<<"YEs"<<endl ; if(root->left == nullptr && root->right != nullptr){return root->right ; }else if(root->left != nullptr && root ->right == nullptr){return root->left ; }else if(root->left != nullptr && root->right != nullptr){TreeNode * cur = root->right ; while(cur->left != nullptr){cur = cur->left ; }cur->left = root->left ; return root->right ; }else {return nullptr ; }}return root ; }

将有序数组转换为二叉搜索树
想到二叉树的性质,根节点是中间节点 。之后把序列分为左子树和右子树 跟先前的序列与二叉搜索树的题有点像。
核心代码

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

把二叉搜索树转换为累加树
题意:使用双指针的算法。不过要改变遍历顺序改为右中左。 之后root-.>val += prev->val ;
核心代码

   void trival(TreeNode * root){if(root == nullptr){return  ; }convertBST(root->right) ;if(pre != nullptr){root->val += pre->val ; }pre  = root ; convertBST(root->left) ; }

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

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

相关文章

赶紧收藏!2024 年最常见 20道 Kafka面试题(四)

上一篇地址&#xff1a;赶紧收藏&#xff01;2024 年最常见 20道 Kafka面试题&#xff08;三&#xff09;-CSDN博客 七、Kafka数据一致性原理是什么&#xff1f; Kafka的数据一致性原理主要依赖于其内部的复制机制、分区策略、领导者与追随者&#xff08;Leader and Follower…

java-成员变量和局部变量

Java中的变量根据其作用域和生命周期可以分为两大类&#xff1a;成员变量&#xff08;Instance Variables&#xff09;和局部变量&#xff08;Local Variables&#xff09;。这两类变量在Java程序中扮演着重要的角色&#xff0c;它们用于存储程序运行时所需的数据。 一、成员变…

贝锐向日葵分组策略:减少重复操作,提升管理效率

面对大数量级的IT设备&#xff0c;如何高效实施管理是运维的关键所在&#xff0c;如何快速准确的对大量的设备按需分组&#xff0c;则是管理精准触达的第一步。 但是&#xff0c;传统的分组方式应付少量设备还可行&#xff0c;设备数量级一旦来到上千台甚至更多时&#xff0c;…

【分红+估值修复】人工智能选股策略》?

今天公告中的部分内容上次去兴业交流的时候跟管理层也聊到了&#xff0c;比如分红、大股东增持、六大新赛道等。 我一直呼吁的管理层增持这次也体现在公告中。 这都体现了上市公司对于维护公司股价和合理估值的重视&#xff0c;对于股东合理投资回报的重视。 对于上市公司而言&…

linux安装docker步骤

步骤1 脚本自动安装 curl -fsSL https://get.docker.com -o get-docker.sh sudo sh get-docker.sh 步骤2 启动Docker服务: sudo systemctl start docker 步骤3 验证Docker是否正确安装并运行一个容器: sudo docker run hello-world 安装正确&#xff0c;则可拉取镜像&am…

C++的std::optional的用法

C++的std::optional的用法 在编程中,处理可能为空的变量或结果是一个常见的挑战。确实,传统的几种方法都有其局限性,可能导致代码的可读性和可维护性降低。如下的方式: 使用特殊值标记: 虽然使用特殊值(如-1、INFINITY、nullptr等)来标记无效或缺失的值很常见,但这种…

在vue3和ant-design-vue的项目中,下拉绑定,显示文字,取值数字

要是以前&#xff0c;用js,jq就很容易实现&#xff0c; 新框架旧写法 <template><a-form><!-- 其他表单项 --><a-form-item label"银行名称"><a-selectv-model:value"state.selectedBankId"placeholder"请选择银行"…

Mongo常用语法(java代码)

1、根据agentId字段分组&#xff0c;并对totalCustomerNum、refundCustomerNum字段 sum求和&#xff0c;同时取别名 Overridepublic List<AgentCountInfoBean> selectCurrentMonthNewResource(Set<String> orderTypeSet, List<String> agentIds,LocalDateTim…

6.4 Go 映射(Map)

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

【vuejs】组件中 data 函数的作用和分析

1. 组件复用性与数据隔离 组件在Vue中是用于复用的&#xff0c;每个组件实例应该拥有自己的独立状态&#xff0c;以避免不同组件实例之间的数据冲突和相互影响。Vue通过将组件的data定义为一个函数来实现这一点。 1.1 组件复用性 组件复用性是指组件可以在多个地方被重复使用…

Java 异常处理详解(如果想知道Java中有关异常处理的知识点,那么只看这一篇就足够了!)

前言&#xff1a;异常处理是 Java 编程中非常重要的一部分&#xff0c;它能够有效地捕获和处理程序运行中的错误&#xff0c;提高代码的健壮性和可靠性。本文将深入探讨 Java 中异常的概念、体系结构、抛出、解决方式以及如何自定义异常&#xff0c;并结合代码案例进行详细解释…

mysql 如果有按照时间范围查询结果

1.前端传2024-06-21 到我们xml sql 文件中默认实际是 2024-06-21 00:00:00 <if test"dto.startTime ! null">and ps.created_at > #{dto.startTime}</if><if test"dto.endTime ! null">and ps.created_at < #{dto.endTime}</if…

Java 面试题:Java 的动态代理是基于什么原理?

编程语言通常有各种不同的分类角度&#xff0c;动态类型和静态类型就是其中一种分类角度&#xff0c;简单区分就是语言类型信息是在运行时检查&#xff0c;还是编译期检查。 与其近似的还有一个对比&#xff0c;就是所谓强类型和弱类型&#xff0c;就是不同类型变量赋值时&…

Stage #1 无过滤的XSS注入:基础与实操

Stage #1 无过滤的XSS注入&#xff1a;基础与实操 跨站脚本攻击&#xff08;XSS&#xff09;是Web安全领域中一种常见的攻击手段。在"XSS Challenges"闯关游戏中&#xff0c;Stage #1专为初学者设计&#xff0c;用于练习无过滤的XSS注入技术。本文将详细介绍这一阶段…

Linux命令篇(六):vi/vim专项

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝您生活愉快&#xff01; 文章目录 一、什么是vim二…

Microsoft Outlook Lite 引入短信功能

随着科技的不断进步&#xff0c;我们的沟通方式也在不断演变。微软最新推出的 Outlook Lite 应用&#xff0c;不仅为我们提供了一个轻量级的电子邮件管理工具&#xff0c;现在更是带来了一项令人兴奋的新功能——短信服务。 Outlook Lite&#xff1a;轻量级&#xff0c;功能全…

【.Net】Linq的使用

文章目录 一、Linq介绍二、在两个数据源联合查询中的使用三、Linq的其他用法 一、Linq介绍 LINQ&#xff08;Language Integrated Query&#xff09;是C#中的一个强大功能&#xff0c;允许您使用统一的语法查询和操作来自不同数据源的数据。 二、在两个数据源联合查询中的使用…

今日好料推荐(ARM嵌入式)

今日好料推荐&#xff08;ARM嵌入式&#xff09; 参考资料在文末获取&#xff0c;关注我&#xff0c;获取优质资源。 给我留言&#xff0c;会帮大家寻找需要的资料。 ARM 嵌入式系统 嵌入式系统在现代电子设备中扮演着至关重要的角色&#xff0c;从智能手机到工业自动化&am…

深入了解 C 语言 Bug

目录 一、引言二、Bug的定义三、Bug的由来四、Bug的影响五、应对 Bug 的方法六、结论 一、引言 1、在 C 语言的编程世界中&#xff0c;Bug 是一个我们无法回避的话题。 2、Bug&#xff0c;简单来说&#xff0c;就是程序中存在的错误或缺陷。它可以表现为程序运行结果的异常、崩…

HALCON-从入门到入门-形态学操作-千变万化的region

1.废话 计算机视觉中的形态学操作是一种基本的数字图像处理技术&#xff0c;主要用于图像的形态结构改变&#xff0c;以便执行前后景分割、形状检测等任务。 膨胀&#xff08;Dilation&#xff09;&#xff1a; 膨胀操作是将结构元素在图像上滑动&#xff0c;如果结构元素与图…