面试题54. 二叉搜索树的第k大节点
示例
js
示例 1:
输入: root = [3,1,4,null,2], k = 1
3
/ \
1 4
\
2
输出: 4
示例 2:
输入: root = [5,3,6,2,4,null,null,1], k = 3
5
/ \
3 6
/ \
2 4
/
1
输出: 4
示例 1:
输入: root = [3,1,4,null,2], k = 1
3
/ \
1 4
\
2
输出: 4
示例 2:
输入: root = [5,3,6,2,4,null,null,1], k = 3
5
/ \
3 6
/ \
2 4
/
1
输出: 4
JS
优化之前(O(n))
js
/**
* @param {TreeNode} root
* @param {number} k
* @return {number}
*/
var kthLargest = function (root, k) {
let res = []
const middle = function (node) {
if (node) {
middle(node.left)
res.unshift(node.val)
middle(node.right)
}
}
middle(root)
return res[k - 1]
};
/**
* @param {TreeNode} root
* @param {number} k
* @return {number}
*/
var kthLargest = function (root, k) {
let res = []
const middle = function (node) {
if (node) {
middle(node.left)
res.unshift(node.val)
middle(node.right)
}
}
middle(root)
return res[k - 1]
};
优化后
js
/**
* @param {TreeNode} root
* @param {number} k
* @return {number}
*/
var kthLargest = function (root, k) {
let res = 0
const middle = function (node) {
if (node) {
middle(node.right)
k--
if (k===0) {
res = node.val
return
}
middle(node.left)
}
}
middle(root)
return res
};
/**
* @param {TreeNode} root
* @param {number} k
* @return {number}
*/
var kthLargest = function (root, k) {
let res = 0
const middle = function (node) {
if (node) {
middle(node.right)
k--
if (k===0) {
res = node.val
return
}
middle(node.left)
}
}
middle(root)
return res
};