डेटा स्ट्रक्चर्स और अल्गोरिद्म - एरे

एरे एक कंटेनर है जो वस्तुओं की एक निश्चित संख्या को पकड़ सकता है और ये आइटम एक ही प्रकार के होने चाहिए। अधिकांश डेटा संरचनाएं अपने एल्गोरिदम को लागू करने के लिए सरणियों का उपयोग करती हैं। ऐरे की अवधारणा को समझने के लिए महत्वपूर्ण शर्तें निम्नलिखित हैं।

  • Element - एक सरणी में संग्रहीत प्रत्येक आइटम को एक तत्व कहा जाता है।

  • Index - एरे में किसी तत्व के प्रत्येक स्थान पर एक संख्यात्मक सूचकांक होता है, जिसका उपयोग तत्व की पहचान करने के लिए किया जाता है।

ऐरे प्रतिनिधित्व

विभिन्न भाषाओं में विभिन्न तरीकों से ऐरे को घोषित किया जा सकता है। चित्रण के लिए, आइए C सरणी घोषणा लें।

विभिन्न भाषाओं में विभिन्न तरीकों से ऐरे को घोषित किया जा सकता है। चित्रण के लिए, आइए C सरणी घोषणा लें।

उपरोक्त उदाहरण के अनुसार, निम्नलिखित महत्वपूर्ण बिंदुओं पर विचार किया जाना है।

  • इंडेक्स 0 से शुरू होता है।

  • ऐरे की लंबाई 10 है जिसका मतलब है कि यह 10 तत्वों को संग्रहीत कर सकता है।

  • प्रत्येक तत्व को इसके सूचकांक के माध्यम से पहुँचा जा सकता है। उदाहरण के लिए, हम इंडेक्स 6 में 9 के रूप में एक तत्व ला सकते हैं।

मूलभूत क्रियाएं

एक सरणी द्वारा समर्थित मूल संचालन निम्नलिखित हैं।

  • Traverse - सभी ऐरे एलिमेंट को एक-एक करके प्रिंट करें।

  • Insertion - दिए गए इंडेक्स में एक तत्व जोड़ता है।

  • Deletion - दिए गए इंडेक्स में एक तत्व को हटाता है।

  • Search - दिए गए इंडेक्स का उपयोग करके या मान द्वारा एक तत्व खोजता है।

  • Update - दिए गए इंडेक्स में एक तत्व को अपडेट करता है।

C में, जब किसी सरणी को आकार के साथ आरंभीकृत किया जाता है, तो यह निम्नलिखित क्रम में अपने तत्वों को डिफॉल्ट मान प्रदान करता है।

डाटा प्रकार डिफ़ॉल्ट मान
bool असत्य
चार 0
पूर्णांक 0
नाव 0.0
दोहरा 0.0f
शून्य
wchar_t 0

ट्रैवर्स ऑपरेशन

यह ऑपरेशन एक एरे के तत्वों के माध्यम से पार करना है।

उदाहरण

निम्नलिखित प्रोग्राम ट्रैवर्स और एरे के तत्वों को प्रिंट करता है:

#include <stdio.h>
main() {
   int LA[] = {1,3,5,7,8};
   int item = 10, k = 3, n = 5;
   int i = 0, j = n;   
   printf("The original array elements are :\n");
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
}

जब हम उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

The original array elements are :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 7 
LA[4] = 8

निवेशन ऑपरेशन

इन्सर्ट ऑपरेशन एक या एक से अधिक डेटा एलिमेंट्स को अरै में सम्मिलित करना है। आवश्यकता के आधार पर, सरणी के आरंभ, अंत या किसी दिए गए सूचकांक में एक नया तत्व जोड़ा जा सकता है।

यहां, हम सम्मिलन ऑपरेशन का एक व्यावहारिक कार्यान्वयन देखते हैं, जहां हम सरणी के अंत में डेटा जोड़ते हैं -

उदाहरण

निम्नलिखित एल्गोरिथ्म का कार्यान्वयन निम्नलिखित है -

#include <stdio.h>

main() {
   int LA[] = {1,3,5,7,8};
   int item = 10, k = 3, n = 5;
   int i = 0, j = n;
   
   printf("The original array elements are :\n");

   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }

   n = n + 1;
	
   while( j >= k) {
      LA[j+1] = LA[j];
      j = j - 1;
   }

   LA[k] = item;

   printf("The array elements after insertion :\n");

   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
}

जब हम उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

The original array elements are :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 7 
LA[4] = 8 
The array elements after insertion :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 10 
LA[4] = 7 
LA[5] = 8

सरणी सम्मिलन ऑपरेशन की अन्य विविधताओं के लिए यहां क्लिक करें

विलोपन ऑपरेशन

विलोपन से तात्पर्य किसी मौजूदा तत्व को सरणी से हटाने और सरणी के सभी तत्वों को फिर से व्यवस्थित करने से है।

कलन विधि

विचार करें LA के साथ एक रैखिक सरणी है N तत्वों और K एक सकारात्मक पूर्णांक है ऐसा K<=N। एलए के K वें स्थान पर उपलब्ध तत्व को हटाने के लिए एल्गोरिथ्म निम्नलिखित है ।

1. Start
2. Set J = K
3. Repeat steps 4 and 5 while J < N
4. Set LA[J] = LA[J + 1]
5. Set J = J+1
6. Set N = N-1
7. Stop

उदाहरण

निम्नलिखित एल्गोरिथ्म का कार्यान्वयन निम्नलिखित है -

#include <stdio.h>

void main() {
   int LA[] = {1,3,5,7,8};
   int k = 3, n = 5;
   int i, j;
   
   printf("The original array elements are :\n");
	
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
    
   j = k;
	
   while( j < n) {
      LA[j-1] = LA[j];
      j = j + 1;
   }
	
   n = n -1;
   
   printf("The array elements after deletion :\n");
	
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
}

जब हम उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

The original array elements are :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 7 
LA[4] = 8 
The array elements after deletion :
LA[0] = 1 
LA[1] = 3 
LA[2] = 7 
LA[3] = 8

सर्च ऑपरेशन

आप इसके मूल्य या इसके सूचकांक के आधार पर एक सरणी तत्व की खोज कर सकते हैं।

कलन विधि

विचार करें LA के साथ एक रैखिक सरणी है N तत्वों और K एक सकारात्मक पूर्णांक है ऐसा K<=N। अनुक्रमिक खोज का उपयोग करके ITEM के मान के साथ एक तत्व को खोजने के लिए एल्गोरिथ्म निम्नलिखित है।

1. Start
2. Set J = 0
3. Repeat steps 4 and 5 while J < N
4. IF LA[J] is equal ITEM THEN GOTO STEP 6
5. Set J = J +1
6. PRINT J, ITEM
7. Stop

उदाहरण

निम्नलिखित एल्गोरिथ्म का कार्यान्वयन निम्नलिखित है -

#include <stdio.h>

void main() {
   int LA[] = {1,3,5,7,8};
   int item = 5, n = 5;
   int i = 0, j = 0;
   
   printf("The original array elements are :\n");
	
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
    
   while( j < n){
      if( LA[j] == item ) {
         break;
      }
		
      j = j + 1;
   }
	
   printf("Found element %d at position %d\n", item, j+1);
}

जब हम उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

The original array elements are :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 7 
LA[4] = 8 
Found element 5 at position 3

अद्यतन अद्यतन करें

अद्यतन ऑपरेशन किसी दिए गए इंडेक्स में सरणी से मौजूदा तत्व को अपडेट करने के लिए संदर्भित करता है।

कलन विधि

विचार करें LA के साथ एक रैखिक सरणी है N तत्वों और K एक सकारात्मक पूर्णांक है ऐसा K<=N। एलए के K वें स्थान पर उपलब्ध तत्व को अपडेट करने के लिए एल्गोरिथ्म निम्नलिखित है ।

1. Start
2. Set LA[K-1] = ITEM
3. Stop

उदाहरण

निम्नलिखित एल्गोरिथ्म का कार्यान्वयन निम्नलिखित है -

#include <stdio.h>

void main() {
   int LA[] = {1,3,5,7,8};
   int k = 3, n = 5, item = 10;
   int i, j;
   
   printf("The original array elements are :\n");
	
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
    
   LA[k-1] = item;

   printf("The array elements after updation :\n");
	
   for(i = 0; i<n; i++) {
      printf("LA[%d] = %d \n", i, LA[i]);
   }
}

जब हम उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

The original array elements are :
LA[0] = 1 
LA[1] = 3 
LA[2] = 5 
LA[3] = 7 
LA[4] = 8 
The array elements after updation :
LA[0] = 1 
LA[1] = 3 
LA[2] = 10 
LA[3] = 7 
LA[4] = 8