刷题笔记22——二叉搜索树BST

从叶到花,或从花到叶,于科研是一个过程,而于生命自身则永远只在此刻。花和叶都是一种记忆方式,果子同时也是种子。生命是闪耀的此刻,不是过程,就像芳香不需要道路一样。 ------顾城《一个人应该活得是他自己并且干净》

  • 二叉搜索树:右子树节点值都比node大,左子树节点值都比node小

1038. 从二叉搜索树到更大和树

java 复制代码
class Solution {
    int sum = 0;
    public TreeNode bstToGst(TreeNode root) {
        if(root != null){
            bstToGst(root.right);
            sum = sum + root.val;
            root.val = sum;
            bstToGst(root.left);
        }
        return root;
    }
}

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

java 复制代码
class Solution {
    int sum = 0;
    public TreeNode convertBST(TreeNode root) {
        sumBST(root);
        return root;
    }

    public void sumBST(TreeNode root){
        if(root==null) return;
        sumBST(root.right);
        sum = sum + root.val;
        root.val = sum;
        sumBST(root.left);
    }
}

AVL 树,红黑树, B+ 树,线段树

230. 二叉搜索树中第K小的元素

java 复制代码
class Solution {
    int m = 0;
    int result = -1;
    public int kthSmallest(TreeNode root, int k) {
        findkth(root,k);
        return result;
    }

    public void findkth(TreeNode root,int k){
        if(root==null) return;
        kthSmallest(root.left,k);
        m++;
        if(m==k){
            result = root.val;
        }
        kthSmallest(root.right,k);
    }
}
相关推荐
伏小白白白1 分钟前
【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
人工智能·算法·机器学习
楚韵天工18 分钟前
宠物服务平台(程序+文档)
java·网络·数据库·spring cloud·编辑器·intellij-idea·宠物
helloworddm20 分钟前
Orleans Stream SubscriptionId 生成机制详解
java·系统架构·c#
失散1324 分钟前
分布式专题——43 ElasticSearch概述
java·分布式·elasticsearch·架构
ajsbxi24 分钟前
【Java 基础】核心知识点梳理
java·开发语言·笔记
无敌最俊朗@34 分钟前
数组-力扣hot56-合并区间
数据结构·算法·leetcode
呱呱巨基42 分钟前
vim编辑器
linux·笔记·学习·编辑器·vim
新子y1 小时前
【小白笔记】普通二叉树(General Binary Tree)和二叉搜索树的最近公共祖先(LCA)
开发语言·笔记·python
聪明的笨猪猪1 小时前
Java JVM “调优” 面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
囚生CY1 小时前
【速写】优化的深度与广度(Adam & Moun)
人工智能·python·算法