刷题笔记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 小时前
JavaWeb 30 天入门:第二十三天 —— 监听器(Listener)
java·开发语言·spring boot·学习·servlet
@小匠3 小时前
Spring Cache 多租户缓存隔离解决方案实践
java·spring·缓存
智码看视界4 小时前
老梁聊全栈系列:(阶段一)架构思维与全局观
java·javascript·架构
黎宇幻生4 小时前
Java全栈学习笔记33
java·笔记·学习
奔跑吧 android5 小时前
【linux kernel 常用数据结构和设计模式】【数据结构 2】【通过一个案例属性list、hlist、rbtree、xarray数据结构使用】
linux·数据结构·list·kernel·rbtree·hlist·xarray
汉克老师5 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯
朗迹 - 张伟5 小时前
Golang安装笔记
开发语言·笔记·golang
Mr_Xuhhh6 小时前
项目需求分析(2)
c++·算法·leetcode·log4j
默默无名的大学生6 小时前
数据结构—顺序表
数据结构·windows