ANSWERS TO EXERCISES ON BINARY SEARCH TREES
1. data:image/s3,"s3://crabby-images/47b91/47b91760f25bf0ad9c8224c152b468655fb2f604" alt=""
data:image/s3,"s3://crabby-images/1fd89/1fd89ce28cb3b1eb822d5ae6a789fd98fb860239" alt=""
2. data:image/s3,"s3://crabby-images/6a4d7/6a4d7e75702811fc0e80c42ab6fff584ca4e935d" alt=""
3. void smaller(link tree, int k) {
if (tree == NULL)
return;
smaller(tree->left, k);
if (tree->key < k) {
printf("%d\n", k);
smaller(tree->right, k);
}
}
4. If the BST is built by Prog. 12.7 or 12.9, the equal keys are on the right.
int searcheq(link x, Key k) {
Key t = key(x->item);
if (h == NULL)
return 0;
if less(k, t)
return searcheq(x->left, k);
else if eq(k, t)
return searcheq(x->right, k) + 1;
else
return searcheq(x->right, k);
}
int STsearcheq(Key k) {
return searcheqR(tree, k);
}
5. Be sure to handle case when left and/or right child is NULL.
int isBST(link x) {
if (x == NULL)
return 1;
else if (x->left == NULL && x->r == NULL)
return 1;
else if (x->left == NULL && x->key <= x->right->key)
return isBST(x->right);
else if (x->right == NULL && x->key >= x->left->key)
return isBST(x->left);
else if (x->key <= x->right->key && x->key >= x->left->key)
return isBST(x->left) && isBST(x->right);
else
return 0;
}