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

修剪二叉搜索树(力扣669)

这道题还是比较复杂,在递归上与之前写过的二叉树的题目都有所不同。如果当前递归到的子树的父节点不在范围中,我们根据节点数值的大小选择进行左递归还是右递归。为什么找到了不满足要求的节点之后,还要进行递归呢?因为该不满足要求的父节点的子树中可能存在满足要求的节点,我们要不断递归子树寻找这些满足要求的节点并向上返回,直到遇到空节点为止。注意这里递归函数的返回值为指向节点的指针,用来返回满足要求的节点。另外,递归到的子树的父节点满足要求时,需要进行链表的连接操作,刚好接住前面所说的满足要求的节点,最后再向上返回该节点,用于之后的连接。大家可以结合我下面的代码及注释理解此题。

代码及注释如下:

/**
 * 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 == NULL){
            return NULL;
        }
        //如果节点值不在范围中,则根据节点值的大小选择进行左递归还是右递归
        if(root -> val < low){
            //这里的递归是为了找到满足要求的子树父节点
            TreeNode* right = trimBST(root -> right,low,high);
            //返回该子树父节点
            return right;
        }
        if(root -> val > high){
            //这里的递归是为了找到满足要求的子树父节点
            TreeNode* left = trimBST(root -> left,low,high);
             //返回该子树父节点
            return left;
        }
        //如果当前节点在范围中,则将当前节点与子树父节点连接
       TreeNode* a =  trimBST(root -> left,low,high);
       TreeNode* b = trimBST(root -> right,low,high);
       root -> left = a;
       root -> right = b;
        //返回连接后的新子树父节点
        return root;
    }
};


http://www.kler.cn/a/533920.html

相关文章:

  • Java基础面试题50题
  • 2024美团春招硬件开发笔试真题及答案解析
  • 关于deepseek的一些普遍误读
  • (dpdk f-stack)-堆栈溢出-野指针-内存泄露(问题定位)
  • 利用Muduo库实现简单且健壮的Echo服务器
  • 录音质检,只质检录音,没有显卡的服务器配置分析
  • 2025最新软件测试面试大全
  • 实现一个 LRU 风格的缓存类
  • java进阶1——JVM
  • 通过C/C++编程语言实现“数据结构”课程中的链表
  • Leetcode—159. 至多包含两个不同字符的最长子串【中等】Plus
  • ip属地是手机号还是手机位置?一文理清
  • 车载以太网__传输层
  • SpringBoot+SpringDataJPA项目中使用EntityManager执行复杂SQL
  • RabbitMQ中的过期时间
  • OCT图像缺陷检测
  • SpringUI Web高端动态交互元件库
  • Django 多数据库
  • vue3 + ElementPlus 封装列表表格组件包含分页
  • AllData数据中台核心菜单十二:数据同步平台
  • [c语言日寄]赋值操作对内存的影响
  • python:递归函数与lambda函数
  • 操作系统1.6
  • Debian 安装 Nextcloud 使用 MariaDB 数据库 + Caddy + PHP-FPM
  • Python 自学秘籍:开启编程之旅,人生苦短,我用python。
  • Python-基于PyQt5,Pillow,pathilb,imageio,moviepy,sys的GIF(动图)制作工具