#include <stdio.h>
#include <stdlib.h>
#define ADD_LENGTH 50
struct node
{
int id;
char agent[12];
int price;
int size; //In square feet
int numBeds;
double numBaths;
int yearBuilt;
char address[ADD_LENGTH];
struct node *left;
struct node *right;
};
struct node * newNode(int id, char str[], int price, int size, int numBeds, double numBaths, int yearBuilt) {
struct node
*temp
= (struct node
*)malloc(sizeof(struct node
)); temp->id = id;
temp->price = price;
temp->numBeds = numBeds;
temp->numBaths = numBaths;
temp->yearBuilt = yearBuilt;
temp->left = temp->right = NULL;
return temp;
}
struct node* insert(struct node* node, int id, char *str, int key, int size, int numBeds, double numBaths, int yearBuilt)
{
/* If the tree is empty, return a new node */
if (node == NULL) return newNode(id, str, key, size, numBeds, numBaths, yearBuilt);
/* Otherwise, recur down the tree */
if (key <= node->price)
node->left = insert(node->left, id, str, key, size, numBeds, numBaths, yearBuilt);
else if (key > node->price)
node->right = insert(node->right, id, str, key, size, numBeds, numBaths, yearBuilt);
/* return the (unchanged) node pointer */
return node;
}
void print(struct node *node) {
printf("%d\n", node
->numBeds
); printf("%lf\n", node
->numBaths
); printf("%d\n", node
->yearBuilt
); }
void findListingByPrice(struct node *node, int maxPrice)
{
if(node == NULL)
{
return;
}else {
findListingByPrice(node->left, maxPrice);
if(node->price <=maxPrice) {
print(node);
}
findListingByPrice(node->right, maxPrice);
}
}
void inorder(struct node *node) {
if(node != NULL) {
inorder(node->left);
inorder(node->right);
}
}
int main()
{
/* Let us create following BST
50
/ \
30 70
/ \ / \
20 40 60 80 */
struct node *root = NULL;
root = insert(root, 1, "hello 1", 50, 5, 5, 4.5, 2010);
insert(root, 2, "hello 2", 30, 5, 6, 4.5, 2010);;
insert(root, 3, "hello 3", 20, 5, 7, 4.5, 2010);
insert(root, 4, "hello 4", 40, 5, 8, 4.5, 2010);
insert(root, 5, "hello 5", 70, 5, 9, 4.5, 2010);
insert(root, 6, "hello 6", 60, 5, 10, 4.5, 2010);
insert(root, 7, "hello 7", 80, 5, 11, 4.5, 2010);
// print inoder traversal of the BST
inorder(root);
findListingByPrice(root, 65);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KI2RlZmluZSBBRERfTEVOR1RIIDUwCnN0cnVjdCBub2RlCnsKICAgIGludCBpZDsKICAgIGNoYXIgYWdlbnRbMTJdOwogICAgaW50IHByaWNlOwogICAgaW50IHNpemU7IC8vSW4gc3F1YXJlIGZlZXQKICAgIGludCBudW1CZWRzOwogICAgZG91YmxlIG51bUJhdGhzOwogICAgaW50IHllYXJCdWlsdDsKICAgIGNoYXIgYWRkcmVzc1tBRERfTEVOR1RIXTsKICAgIHN0cnVjdCBub2RlICpsZWZ0OwogICAgc3RydWN0IG5vZGUgKnJpZ2h0Owp9OwpzdHJ1Y3Qgbm9kZSAqIG5ld05vZGUoaW50IGlkLCBjaGFyIHN0cltdLCBpbnQgcHJpY2UsIGludCBzaXplLCBpbnQgbnVtQmVkcywgZG91YmxlIG51bUJhdGhzLCBpbnQgeWVhckJ1aWx0KSB7CglzdHJ1Y3Qgbm9kZSAqdGVtcCA9IChzdHJ1Y3Qgbm9kZSopbWFsbG9jKHNpemVvZihzdHJ1Y3Qgbm9kZSkpOwoJdGVtcC0+aWQgPSBpZDsKCXRlbXAtPnByaWNlID0gcHJpY2U7Cgl0ZW1wLT5udW1CZWRzID0gbnVtQmVkczsKCXRlbXAtPm51bUJhdGhzID0gbnVtQmF0aHM7Cgl0ZW1wLT55ZWFyQnVpbHQgPSB5ZWFyQnVpbHQ7Cgl0ZW1wLT5sZWZ0ID0gdGVtcC0+cmlnaHQgPSBOVUxMOwoJcmV0dXJuIHRlbXA7Cn0Kc3RydWN0IG5vZGUqIGluc2VydChzdHJ1Y3Qgbm9kZSogbm9kZSwgaW50IGlkLCBjaGFyICpzdHIsIGludCBrZXksIGludCBzaXplLCBpbnQgbnVtQmVkcywgZG91YmxlIG51bUJhdGhzLCBpbnQgeWVhckJ1aWx0KQp7CiAgICAvKiBJZiB0aGUgdHJlZSBpcyBlbXB0eSwgcmV0dXJuIGEgbmV3IG5vZGUgKi8KICAgIGlmIChub2RlID09IE5VTEwpIHJldHVybiBuZXdOb2RlKGlkLCBzdHIsIGtleSwgc2l6ZSwgbnVtQmVkcywgbnVtQmF0aHMsIHllYXJCdWlsdCk7CiAKICAgIC8qIE90aGVyd2lzZSwgcmVjdXIgZG93biB0aGUgdHJlZSAqLwogICAgaWYgKGtleSA8PSBub2RlLT5wcmljZSkKICAgICAgICBub2RlLT5sZWZ0ICA9IGluc2VydChub2RlLT5sZWZ0LCBpZCwgc3RyLCBrZXksIHNpemUsIG51bUJlZHMsIG51bUJhdGhzLCB5ZWFyQnVpbHQpOwogICAgZWxzZSBpZiAoa2V5ID4gbm9kZS0+cHJpY2UpCiAgICAgICAgbm9kZS0+cmlnaHQgPSBpbnNlcnQobm9kZS0+cmlnaHQsIGlkLCBzdHIsIGtleSwgc2l6ZSwgbnVtQmVkcywgbnVtQmF0aHMsIHllYXJCdWlsdCk7ICAgCiAKICAgIC8qIHJldHVybiB0aGUgKHVuY2hhbmdlZCkgbm9kZSBwb2ludGVyICovCiAgICByZXR1cm4gbm9kZTsKfQp2b2lkIHByaW50KHN0cnVjdCBub2RlICpub2RlKSB7CglwcmludGYoIiVkXG4iLCBub2RlLT5pZCk7CglwcmludGYoIiVkXG4iLCBub2RlLT5wcmljZSk7CglwcmludGYoIiVkXG4iLCBub2RlLT5udW1CZWRzKTsKCXByaW50ZigiJWxmXG4iLCBub2RlLT5udW1CYXRocyk7CglwcmludGYoIiVkXG4iLCBub2RlLT55ZWFyQnVpbHQpOwp9CnZvaWQgZmluZExpc3RpbmdCeVByaWNlKHN0cnVjdCBub2RlICpub2RlLCBpbnQgbWF4UHJpY2UpCnsKICAgIGlmKG5vZGUgPT0gTlVMTCkKICAgIHsKICAgICAgICByZXR1cm47CiAgICB9ZWxzZSB7CgkJZmluZExpc3RpbmdCeVByaWNlKG5vZGUtPmxlZnQsIG1heFByaWNlKTsKCQlpZihub2RlLT5wcmljZSA8PW1heFByaWNlKSB7CgkJCXByaW50ZigiRm91bmQgMVxuIik7CgkgICAgCXByaW50KG5vZGUpOwoJCX0KCQlmaW5kTGlzdGluZ0J5UHJpY2Uobm9kZS0+cmlnaHQsIG1heFByaWNlKTsKICAgIH0KICAgIAogICAKfQp2b2lkIGlub3JkZXIoc3RydWN0IG5vZGUgKm5vZGUpIHsKCWlmKG5vZGUgIT0gTlVMTCkgewoJCWlub3JkZXIobm9kZS0+bGVmdCk7CgkJcHJpbnRmKCIlZCAiLCBub2RlLT5wcmljZSk7CgkJaW5vcmRlcihub2RlLT5yaWdodCk7Cgl9Cn0KaW50IG1haW4oKQp7CiAgICAvKiBMZXQgdXMgY3JlYXRlIGZvbGxvd2luZyBCU1QKICAgICAgICAgICAgICA1MAogICAgICAgICAgIC8gICAgIFwKICAgICAgICAgIDMwICAgICAgNzAKICAgICAgICAgLyAgXCAgICAvICBcCiAgICAgICAyMCAgIDQwICA2MCAgIDgwICovCiAgICBzdHJ1Y3Qgbm9kZSAqcm9vdCA9IE5VTEw7CiAgICByb290ID0gaW5zZXJ0KHJvb3QsIDEsICJoZWxsbyAxIiwgNTAsIDUsIDUsIDQuNSwgMjAxMCk7CiAgICBpbnNlcnQocm9vdCwgMiwgImhlbGxvIDIiLCAzMCwgNSwgNiwgIDQuNSwgMjAxMCk7OwogICAgaW5zZXJ0KHJvb3QsIDMsICJoZWxsbyAzIiwgMjAsIDUsIDcsICA0LjUsIDIwMTApOwogICAgaW5zZXJ0KHJvb3QsIDQsICJoZWxsbyA0IiwgNDAsIDUsIDgsIDQuNSwgMjAxMCk7CiAgICBpbnNlcnQocm9vdCwgNSwgImhlbGxvIDUiLCA3MCwgNSwgOSwgNC41LCAyMDEwKTsKICAgIGluc2VydChyb290LCA2LCAiaGVsbG8gNiIsIDYwLCA1LCAxMCwgNC41LCAyMDEwKTsKICAgIGluc2VydChyb290LCA3LCAiaGVsbG8gNyIsIDgwLCA1LCAxMSwgNC41LCAyMDEwKTsKICAKICAgIC8vIHByaW50IGlub2RlciB0cmF2ZXJzYWwgb2YgdGhlIEJTVAogICAgaW5vcmRlcihyb290KTsKICAgIGZpbmRMaXN0aW5nQnlQcmljZShyb290LCA2NSk7CiAgCiAgICByZXR1cm4gMDsKfQ==