刷题笔记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);
    }
}
相关推荐
桦说编程2 分钟前
简单方法实现子任务耗时统计
java·后端·监控
爱笑的眼睛116 分钟前
超越可视化:降维算法组件的深度解析与工程实践
java·人工智能·python·ai
凉、介9 分钟前
深入 QEMU Guest Agent:虚拟机内外通信的隐形纽带
c语言·笔记·学习·嵌入式·虚拟化
盖世英雄酱5813621 分钟前
物品超领取损失1万事故复盘(一)
java·后端
CryptoRzz26 分钟前
印度尼西亚(IDX)股票数据对接开发
java·后端·websocket·web3·区块链
njsgcs33 分钟前
SIMA2 论文阅读 Google 任务设定器、智能体、奖励模型
人工智能·笔记
清铎34 分钟前
leetcode_day12_滑动窗口_《绝境求生》
python·算法·leetcode·动态规划
linweidong39 分钟前
嵌入式电机:如何在低速和高负载状态下保持FOC(Field-Oriented Control)算法的电流控制稳定?
stm32·单片机·算法
踩坑记录1 小时前
leetcode hot100 42 接雨水 hard 双指针
leetcode