230 二叉搜索树中第K小的元素
给定一个二叉搜索树的根节点 root ,和一个整数 k ,请你设计一个算法查找其中第 k 个最小元素(从 1 开始计数)。
示例 1:
输入:root = [3,1,4,null,2], k = 1
输出:1
示例 2:
输入:root = [5,3,6,2,4,null,null,1], k = 3
输出:3
提示:
树中的节点数为 n 。
1
<
=
k
<
=
n
<
=
1
0
4
1 <= k <= n <= 10^4
1<=k<=n<=104
0
<
=
N
o
d
e
.
v
a
l
<
=
1
0
4
0 <= Node.val <= 10^4
0<=Node.val<=104
进阶:如果二叉搜索树经常被修改(插入/删除操作)并且你需要频繁地查找第 k 小的值,你将如何优化算法?
思路
还是利用二叉搜索树中序遍历后可得到严格递增的序列。最后直接返回数组的第k个元素就可以。
代码
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left),
* right(right) {}
* };
*/
class Solution {
public:
void inOrder(TreeNode* root, vector<int>& v) {
if (root == nullptr) {
return;
}
inOrder(root->left, v);
v.push_back(root->val);
inOrder(root->right, v);
}
int kthSmallest(TreeNode* root, int k) {
vector<int> ans;
inOrder(root, ans);
return ans[k-1];
}
};