समानांतर एल्गोरिथम - संरचना

किसी भी एल्गोरिथ्म को ठीक से लागू करने के लिए, यह बहुत महत्वपूर्ण है कि आप एक उचित डेटा संरचना का चयन करें। ऐसा इसलिए है क्योंकि डेटा संरचना पर किया गया कोई विशेष ऑपरेशन किसी अन्य डेटा संरचना पर किए गए समान ऑपरेशन की तुलना में अधिक समय ले सकता है।

Example- एक सरणी का उपयोग करके एक सेट में i वें तत्व को एक्सेस करने के लिए एक निरंतर समय लग सकता है लेकिन एक लिंक की गई सूची का उपयोग करके, उसी ऑपरेशन को करने के लिए आवश्यक समय एक बहुपद बन सकता है।

इसलिए, डेटा संरचना का चयन वास्तुकला और संचालन के प्रकार पर विचार करना चाहिए।

निम्नलिखित डेटा संरचनाएं आमतौर पर समानांतर प्रोग्रामिंग में उपयोग की जाती हैं -

  • लिंक्ड सूची
  • Arrays
  • हाइपरक्यूब नेटवर्क

लिंक्ड सूची

एक लिंक की गई सूची एक डेटा संरचना है जिसमें पॉइंटर्स द्वारा शून्य या अधिक नोड्स जुड़े हुए हैं। नोड्स लगातार मेमोरी स्थानों पर कब्जा कर सकते हैं या नहीं कर सकते हैं। प्रत्येक नोड के दो या तीन भाग होते हैं - एकdata part डेटा संग्रहीत करता है और अन्य दो हैं link fieldsपिछले या अगले नोड के पते को संग्रहीत करें। पहला नोड का पता बाहरी पॉइंटर में संग्रहीत होता है जिसे कहा जाता हैhead। अंतिम नोड, के रूप में जाना जाता हैtail, आम तौर पर कोई पता नहीं होता है।

तीन प्रकार की लिंक्ड लिस्ट हैं -

  • सिंगली लिंक्ड लिस्ट
  • संदेह से जुड़ी सूची
  • सर्कुलर लिंक्ड लिस्ट

सिंगली लिंक्ड लिस्ट

एक एकल लिंक की गई सूची के नोड में डेटा और अगले नोड का पता होता है। बाहरी सूचक कहा जाता हैhead पहले नोड का पता संग्रहीत करता है।

संदेह से जुड़ी सूची

एक डबल लिंक की गई सूची के नोड में डेटा और पिछले और अगले नोड दोनों का पता होता है। बाहरी सूचक कहा जाता हैhead पहले नोड और बाहरी पॉइंटर नामक पते को संग्रहीत करता है tail अंतिम नोड का पता संग्रहीत करता है।

सर्कुलर लिंक्ड लिस्ट

एक सर्कुलर लिंक्ड लिस्ट इस बात को छोड़कर सिंगली लिंक्ड लिस्ट से काफी मिलती-जुलती है, क्योंकि पिछले नोड ने पहले नोड के पते को बचाया था।

सरणियों

एक सरणी एक डेटा संरचना है जहां हम समान प्रकार के डेटा को संग्रहीत कर सकते हैं। यह एक आयामी या बहुआयामी हो सकता है। ऐरे को सांख्यिकीय या गतिशील रूप से बनाया जा सकता है।

  • में statically declared arrays, संकलन के समय सरणियों के आयाम और आकार को जाना जाता है।

  • में dynamically declared arrays, सरणी का आयाम और आकार रनटाइम पर जाना जाता है।

साझा मेमोरी प्रोग्रामिंग के लिए, सरणियों का उपयोग एक आम मेमोरी के रूप में किया जा सकता है और डेटा समानांतर प्रोग्रामिंग के लिए, उन्हें उप-सरणियों में विभाजित करके उपयोग किया जा सकता है।

हाइपरक्यूब नेटवर्क

हाइपरक्यूब वास्तुकला उन समानांतर एल्गोरिदम के लिए सहायक है जहां प्रत्येक कार्य को अन्य कार्यों के साथ संवाद करना पड़ता है। हाइपरक्यूब टोपोलॉजी आसानी से रिंग और मेष जैसे अन्य टोपोलॉजी को एम्बेड कर सकती है। इसे एन-क्यूब्स के रूप में भी जाना जाता है, जहांnआयामों की संख्या है। एक हाइपरक्यूब का निर्माण पुनरावर्ती रूप से किया जा सकता है।