डेटा संरचना - बाइनरी सर्च ट्री
एक बाइनरी सर्च ट्री (BST) एक पेड़ है जिसमें सभी नोड्स नीचे वर्णित गुणों का पालन करते हैं -
बाएं उप-पेड़ की कुंजी का मूल्य उसके माता-पिता (रूट) नोड की कुंजी के मूल्य से कम है।
सही उप-पेड़ की कुंजी का मूल्य उसके मूल (मूल) नोड की कुंजी के मूल्य से अधिक या उसके बराबर है।
इस प्रकार, BST अपने सभी उप-वृक्षों को दो खंडों में विभाजित करता है; बाएं उप-पेड़ और सही उप-पेड़ और इसे इस प्रकार परिभाषित किया जा सकता है -
left_subtree (keys) < node (key) ≤ right_subtree (keys)
प्रतिनिधित्व
BST एक तरह से व्यवस्थित नोड्स का संग्रह है जहां वे BST संपत्तियों को बनाए रखते हैं। प्रत्येक नोड में एक कुंजी और एक संबद्ध मूल्य होता है। खोज करते समय, वांछित कुंजी की तुलना BST में कुंजियों से की जाती है और यदि पाया जाता है, तो संबंधित मान पुनः प्राप्त होता है।
निम्नलिखित BST का एक चित्रमय प्रतिनिधित्व है -
हम मानते हैं कि रूट नोड कुंजी (27) में बाईं उप-ट्री पर सभी कम-मूल्यवान कुंजियां हैं और दाएं उप-पेड़ पर उच्च मूल्यवान कुंजी हैं।
मूलभूत क्रियाएं
एक पेड़ के बुनियादी संचालन निम्नलिखित हैं -
Search - एक पेड़ में एक तत्व खोजता है।
Insert - एक पेड़ में एक तत्व सम्मिलित करता है।
Pre-order Traversal - एक पूर्व-क्रम तरीके से एक पेड़ का पता लगाता है।
In-order Traversal - एक पेड़ को एक इन-ऑर्डर तरीके से ट्रैवर्स करता है।
Post-order Traversal - एक पेड़ को पोस्ट-ऑर्डर तरीके से लगाया जाता है।
नोड
कुछ डेटा वाले नोड को परिभाषित करें, इसके बाएं और दाएं बच्चे के नोड्स के संदर्भ।
struct node {
int data;
struct node *leftChild;
struct node *rightChild;
};
सर्च ऑपरेशन
जब भी किसी तत्व को खोजना हो, रूट नोड से खोजना शुरू करें। फिर यदि डेटा कुंजी मूल्य से कम है, तो बाएं सबट्री में तत्व की खोज करें। अन्यथा, सही उपशीर्षक में तत्व की खोज करें। प्रत्येक नोड के लिए समान एल्गोरिथ्म का पालन करें।
कलन विधि
struct node* search(int data){
struct node *current = root;
printf("Visiting elements: ");
while(current->data != data){
if(current != NULL) {
printf("%d ",current->data);
//go to left tree
if(current->data > data){
current = current->leftChild;
} //else go to right tree
else {
current = current->rightChild;
}
//not found
if(current == NULL){
return NULL;
}
}
}
return current;
}
ऑपरेशन डालें
जब भी कोई तत्व सम्मिलित करना हो, तो पहले उसके उचित स्थान का पता लगाएं। रूट नोड से खोजना शुरू करें, फिर यदि डेटा कुंजी मूल्य से कम है, तो बाएं सबट्री में खाली स्थान खोजें और डेटा डालें। अन्यथा, सही सबट्री में खाली स्थान खोजें और डेटा डालें।
कलन विधि
void insert(int data) {
struct node *tempNode = (struct node*) malloc(sizeof(struct node));
struct node *current;
struct node *parent;
tempNode->data = data;
tempNode->leftChild = NULL;
tempNode->rightChild = NULL;
//if tree is empty
if(root == NULL) {
root = tempNode;
} else {
current = root;
parent = NULL;
while(1) {
parent = current;
//go to left of the tree
if(data < parent->data) {
current = current->leftChild;
//insert to the left
if(current == NULL) {
parent->leftChild = tempNode;
return;
}
} //go to right of the tree
else {
current = current->rightChild;
//insert to the right
if(current == NULL) {
parent->rightChild = tempNode;
return;
}
}
}
}
}