669. 修剪二叉搜索树

思路

二叉搜索树(BST)的修剪功能。通过递归遍历树节点,移除所有值不在给定范围low, high内的节点。对于小于low的节点,保留其右子树;对于大于high的节点,保留其左子树。算法处理了根节点可能被移除的特殊情况,并重新连接父节点与保留的子树。最终返回修剪后的BST根节点,确保所有节点值都在指定范围内。

代码

cpp 复制代码
class Solution {
public:
    int l,h;
    TreeNode* r;
    int qx(TreeNode* a,TreeNode* syc,bool f) {
        if(!a) {
            return 0;
        }
        qx(a->left,a,0);
        qx(a->right,a,1);
        if(a->val<=l) {
            a->left=nullptr;
            if(a->val<l) {
                if(a==r) {
                    r=a->right;
                }
                else {
                    if(syc) { 
                        if(f) {
                            syc->right=a->right;
                        }
                        else {
                            syc->left=a->right;
                        }
                    }
                }          
            }
        }
        else {
            if(a->val>=h) {
                a->right=nullptr;
                if(a->val>h) {
                    if(a==r) {
                        r=a->left;
                    }
                    else {
                        if(syc) { 
                            if(f) {
                                syc->right=a->left;
                            }
                            else {
                                syc->left=a->left;
                            }
                        }
                    }       
                }
            }   
        }     
        return 0;
    }
    TreeNode* trimBST(TreeNode* root, int low, int high) {
        l=low;
        h=high;
        r=root;
        qx(r,nullptr,0);
        return r;
    }
相关推荐
Frostnova丶16 小时前
【算法笔记】数学知识
笔记·算法
吴可可12317 小时前
AutoCAD 2016与2014二次开发关键差异
算法
雨白18 小时前
哈希:以时间换空间的算法实战
算法
San813_LDD20 小时前
[数据结构]LeetCode学习
数据结构·算法·图论
x1387028595720 小时前
c语言排雷游戏(基础版9*9)
c语言·算法·游戏
sheeta199821 小时前
LeetCode 每日一题笔记 日期:2026.06.06 题目:2196. 根据描述创建二叉树
笔记·算法·leetcode
小欣加油21 小时前
leetcode994 腐烂的橘子
数据结构·c++·算法·leetcode·bfs
QuZero1 天前
Guava Cache Deep Dive
java·后端·算法·guava
随意起个昵称1 天前
线性dp-LIS题目4(A Twisty Movement)
算法·动态规划