从叶到花,或从花到叶,于科研是一个过程,而于生命自身则永远只在此刻。花和叶都是一种记忆方式,果子同时也是种子。生命是闪耀的此刻,不是过程,就像芳香不需要道路一样。 ——顾城《一个人应该活得是他自己并且干净》
- 二叉搜索树:右子树节点值都比node大,左子树节点值都比node小
1038. 从二叉搜索树到更大和树
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. 把二叉搜索树转换为累加树
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小的元素
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);
}
}