Thursday, May 14, 2015

Search Range in a Binary Search Tree

来源:G4G

原帖:http://www.geeksforgeeks.org/print-bst-keys-in-the-given-range/

题目:
Given two values k1 and k2 (where k1 < k2) and a root pointer to a Binary Search Tree. Print all the keys of tree in range k1 to k2. i.e. print all x such that k1<=x<=k2 and x is a key of given BST. Print all the keys in increasing order. For example, if k1 = 10 and k2 = 22, then your function should print 12, 20 and 22.

Algorithm:
1) If value of root’s key is greater than k1, then recursively call in left subtree.
2) If value of root’s key is in range, then print the root’s key.
3) If value of root’s key is smaller than k2, then recursively call in right subtree.

代码:
 struct TreeNode {  
   int val;  
   TreeNode* left;  
   TreeNode* right;  
   TreeNode(int v) : val(v), left(NULL), right(NULL) {}  
 };  
   
 void searchRangeHelper(TreeNode* root, int k1, int k2, vector<int> &result) {  
   if (!root) return;  
   /* Since the desired o/p is sorted, recurse for left subtree first  
    If root->val is greater than k1, then only we can get o/p keys in left subtree */  
   if (root->val > k1) {  
     searchRangeHelper(root->left, k1, k2, result);  
   }    
   /* if root's val lies in range, then prints root's val */  
   if (root->val >= k1 && root->val <= k2) {  
     result.push_back(root->val);  
   }  
   /* If root->val is smaller than k2, then only we can get o/p keys in right subtree */  
   if (root->val < k2) {  
     searchRangeHelper(root->right, k1, k2, result);  
   }  
 }  
   
 vector<int> searchRange(TreeNode* root, int k1, int k2) {  
   vector<int> result;  
   searchRangeHelper(root, k1, k2, result);  
   return result;  
 }  

No comments:

Post a Comment