डेटा संरचना और एल्गोरिदम - ट्री
ट्री किनारों द्वारा जुड़े नोड्स का प्रतिनिधित्व करता है। हम बाइनरी ट्री या बाइनरी सर्च ट्री पर विशेष रूप से चर्चा करेंगे।
बाइनरी ट्री एक विशेष डाटास्ट्रक्चर है जिसका उपयोग डेटा स्टोरेज के उद्देश्यों के लिए किया जाता है। एक बाइनरी ट्री में एक विशेष शर्त है कि प्रत्येक नोड में अधिकतम दो बच्चे हो सकते हैं। एक बाइनरी ट्री में एक ऑर्डर किए गए सरणी और लिंक की गई सूची दोनों के फायदे हैं, जैसे कि खोज एक क्रमबद्ध सरणी में है और प्रविष्टि सूची में प्रविष्टि या विलोपन ऑपरेशन उतनी ही तेजी से होते हैं।
महत्वपूर्ण शर्तें
पेड़ के संबंध में निम्नलिखित महत्वपूर्ण शर्तें हैं।
Path - पथ एक पेड़ के किनारों के साथ नोड्स के अनुक्रम को संदर्भित करता है।
Root- पेड़ के शीर्ष पर स्थित नोड को रूट कहा जाता है। प्रति पेड़ केवल एक जड़ और जड़ नोड से किसी भी नोड के लिए एक रास्ता है।
Parent - रूट नोड को छोड़कर किसी भी नोड में एक किनारे ऊपर की ओर अभिभावक नामक नोड होता है।
Child - इसके किनारे से नीचे दिए गए नोड से नीचे के नोड को उसका बच्चा नोड कहा जाता है।
Leaf - जिस नोड में कोई बच्चा नोड नहीं होता है, उसे लीफ नोड कहा जाता है।
Subtree - उपशीर्षक एक नोड के वंशज का प्रतिनिधित्व करता है।
Visiting - जब नोड पर नियंत्रण होता है, तो विजिटिंग एक नोड के मूल्य की जांच करने के लिए संदर्भित करता है।
Traversing - ट्रैवर्सिंग का मतलब एक विशिष्ट क्रम में नोड्स से गुजरना है।
Levels- एक नोड का स्तर एक नोड की पीढ़ी का प्रतिनिधित्व करता है। यदि रूट नोड 0 के स्तर पर है, तो इसका अगला बच्चा नोड स्तर 1 पर है, इसका पोता 2 स्तर पर है, और इसी तरह।
keys - कुंजी एक नोड के मूल्य को दर्शाता है जिसके आधार पर एक नोड के लिए एक खोज ऑपरेशन किया जाना है।
बाइनरी सर्च ट्री रिप्रेजेंटेशन
बाइनरी सर्च ट्री एक विशेष व्यवहार प्रदर्शित करता है। एक नोड के बाएं बच्चे का मूल्य उसके माता-पिता के मूल्य से कम होना चाहिए और नोड के दाएं बच्चे का मूल्य उसके मूल मूल्य से अधिक होना चाहिए।
हम नोड ऑब्जेक्ट का उपयोग करके पेड़ को लागू करने जा रहे हैं और उन्हें संदर्भों के माध्यम से जोड़ रहे हैं।
पेड़ का नोड
ट्री नोड लिखने के लिए कोड नीचे दिए गए के समान होगा। इसमें एक डेटा हिस्सा है और इसके बाएं और दाएं बच्चे के नोड्स हैं।
struct node {
int data;
struct node *leftChild;
struct node *rightChild;
};
एक पेड़ में, सभी नोड्स सामान्य निर्माण साझा करते हैं।
BST बेसिक ऑपरेशंस
एक बाइनरी खोज ट्री डेटा संरचना पर किए जा सकने वाले मूल संचालन निम्नलिखित हैं -
Insert - एक पेड़ में एक तत्व सम्मिलित करता है / एक पेड़ बनाता है।
Search - एक पेड़ में एक तत्व खोजता है।
Preorder Traversal - एक पूर्व-क्रम तरीके से एक पेड़ का पता लगाता है।
Inorder Traversal - एक पेड़ को एक इन-ऑर्डर तरीके से ट्रैवर्स करता है।
Postorder Traversal - एक पेड़ को पोस्ट-ऑर्डर तरीके से लगाया जाता है।
हम इस अध्याय में एक पेड़ की संरचना बनाने (डालने) और एक पेड़ में एक डेटा आइटम की खोज करना सीखेंगे। हम आने वाले अध्याय में पेड़ की ट्रेसिंग विधियों के बारे में जानेंगे।
ऑपरेशन डालें
बहुत पहले सम्मिलन पेड़ बनाता है। बाद में, जब भी कोई तत्व सम्मिलित करना हो, तो पहले उसके उचित स्थान का पता लगाएं। रूट नोड से खोजना शुरू करें, फिर यदि डेटा कुंजी मूल्य से कम है, तो बाएं सबट्री में खाली स्थान खोजें और डेटा डालें। अन्यथा, सही सबट्री में खाली स्थान खोजें और डेटा डालें।
कलन विधि
If root is NULL
then create root node
return
If root exists then
compare the data with node.data
while until insertion position is located
If data is greater than node.data
goto right subtree
else
goto left subtree
endwhile
insert data
end If
कार्यान्वयन
सम्मिलित फ़ंक्शन के कार्यान्वयन को इस तरह देखना चाहिए -
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, create root node
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;
}
}
}
}
}
सर्च ऑपरेशन
जब भी किसी तत्व को खोजना हो, तो रूट नोड से खोजना शुरू करें, फिर यदि डेटा कुंजी मान से कम है, तो बाएं सबट्री में तत्व की खोज करें। अन्यथा, सही उपशीर्षक में तत्व की खोज करें। प्रत्येक नोड के लिए समान एल्गोरिथ्म का पालन करें।
कलन विधि
If root.data is equal to search.data
return root
else
while data not found
If data is greater than node.data
goto right subtree
else
goto left subtree
If data found
return node
endwhile
return data not found
end if
इस एल्गोरिथ्म के कार्यान्वयन को इस तरह दिखना चाहिए।
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;
}
}
बाइनरी सर्च ट्री डेटा संरचना के कार्यान्वयन के बारे में जानने के लिए, कृपया यहां क्लिक करें ।