給定一個二叉搜索樹,編寫一個函數 kthSmallest 來查找其中第 k 個最小的元素。
說明:
你可以假設 k 總是有效的,1 ≤ k ≤ 二叉搜索樹元素個數。
思路: 二叉搜索樹因其有序,故采用中序遍歷,可以得到第K小的元素。
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: int kthSmallest(TreeNode* root, int k) { int index = k; int kth = 0; TreeNode* find = findKth(root, index, kth); if(find) return find->val; return -1; } TreeNode* findKth(TreeNode* root, int index, int &k){ if(root == NULL) { return NULL; } //左子樹<根節點<右子樹 TreeNode* left = findKth(root->left,index, k); if(left) return left; k = k+1; if(k == index){ // cout << root->val << ","; return root; } TreeNode* right = findKth(root->right, index, k); if(right) return right; else return NULL; //return right? right:left; } };