题目描述
Given a binary search tree, write a function kthSmallest to find the kth smallest element in it.
Note:
You may assume k is always valid, 1 ≤ k ≤ BST’s total elements.
Example 1:
Input: root = [3,1,4,null,2], k = 1
3
/
1 4
2
Output: 1
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/kth-smallest-element-in-a-bst
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码
通过构造 BST 的中序遍历序列,则第 k-1 个元素就是第 k 小的元素
class Solution {
public ArrayList<Integer> inorder(TreeNode root, ArrayList<Integer> arr) {
if (root == null) return arr;
inorder(root.left, arr);
arr.add(root.val);
inorder(root.right, arr);
return arr;
}
public int kthSmallest(TreeNode root, int k) {
ArrayList<Integer> nums = inorder(root, new ArrayList<Integer>());
return nums.get(k - 1);
}
}
写法二(理解浅)
使用index正向计数
#include <iostream>
using namespace std;
/// Definition for a binary tree node.
struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};
/// Inorder Traversal
/// Time Complexity: O(n)
/// Space Complexity: O(h) where h is the height of the BST
class Solution {
private:
int index;
public:
int kthSmallest(TreeNode* root, int k) {
index = 0;
return kthSmallestNode(root, k)->val;
}
private:
TreeNode* kthSmallestNode(TreeNode* node, int k){
if(node == NULL)
return NULL;
TreeNode* res = kthSmallestNode(node->left, k);
if(res) return res;
index ++;
if(index == k)
return node;
return kthSmallestNode(node->right, k);
}
};
int main() {
return 0;
}