अंतर्निहित डेटा संरचना: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
 
(6 intermediate revisions by 3 users not shown)
Line 1: Line 1:
[[कंप्यूटर विज्ञान]] में, अंतर्निहित [[डेटा संरचना]] या अंतरिक्ष-कुशल डेटा संरचना डेटा संरचना है जो मुख्य या आवश्यक डेटा के अलावा बहुत कम जानकारी संग्रहीत करती है: डेटा संरचना जिसके लिए कम [[ओवरहेड (कंप्यूटिंग)]] की आवश्यकता होती है। उन्हें अंतर्निहित कहा जाता है क्योंकि तत्वों की स्थिति तत्वों के बीच अर्थ और संबंध रखती है; तत्वों के बीच ''स्पष्ट'' संबंध देने के लिए पॉइंटर (कंप्यूटर विज्ञान) के उपयोग से इसकी तुलना की जाती है। कम ओवरहेड की परिभाषाएँ अलग-अलग होती हैं, लेकिन आम तौर पर इसका मतलब निरंतर ओवरहेड होता है; बड़े O अंकन में, ''O''(1) ओवरहेड। कम प्रतिबंधात्मक परिभाषा [[संक्षिप्त डेटा संरचना]] है, जो अधिक ओवरहेड की अनुमति देती है।
[[कंप्यूटर विज्ञान]] में, '''अंतर्निहित [[डेटा संरचना]]''' या '''स्पेस-कुशल डेटा संरचना एक''' डेटा संरचना है जो मुख्य या आवश्यक डेटा के अतिरिक्त बहुत कम जानकारी संग्रहीत करती है: डेटा संरचना जिसके लिए कम [[ओवरहेड (कंप्यूटिंग)]] की आवश्यकता होती है। उन्हें अंतर्निहित कहा जाता है क्योंकि तत्वों की स्थिति तत्वों के बीच अर्थ और संबंध रखती है; यह तत्वों के बीच ''स्पष्ट'' संबंध देने के लिए पॉइंटर (कंप्यूटर विज्ञान) के उपयोग से इसकी तुलना की जाती है। कम ओवरहेड की परिभाषाएँ अलग-अलग होती हैं, किन्तु सामान्यतः बड़े O नोटेशन, O(1) ओवरहेड में इसका अर्थ निरंतर ओवरहेड होता है। एक कम प्रतिबंधात्मक परिभाषा एक [[संक्षिप्त डेटा संरचना]] है, जो अधिक ओवरहेड की अनुमति देती है।


== परिभाषा ==
== परिभाषा ==
अंतर्निहित डेटा संरचना स्थिरांक वाली होती है {{math|''O''(1)}} स्पेस ओवरहेड ([[सूचना-सैद्धांतिक]] निचली सीमा के ऊपर)
अंतर्निहित डेटा संरचना {{math|''O''(1)}} स्पेस ओवरहेड ([[सूचना-सैद्धांतिक]] निचली सीमा के ऊपर) स्थिरांक वाली होती है।


ऐतिहासिक रूप से, {{harvtxt|Munro|Suwanda|1980}} ने अंतर्निहित डेटा संरचना (और पर कार्य करने वाले एल्गोरिदम) को ऐसी संरचना के रूप में परिभाषित किया है जिसमें संरचनात्मक जानकारी पॉइंटर्स में स्पष्ट होने के बजाय डेटा संग्रहीत करने के तरीके में अंतर्निहित होती है। वे परिभाषा में कुछ हद तक अस्पष्ट हैं, इसे सबसे सख्ती से एकल सरणी के रूप में परिभाषित करते हैं, जिसमें केवल आकार बरकरार रखा जाता है (ओवरहेड की एकल संख्या),<ref>"Thus, only a simple array is needed for the data.", p. 236; "We will draw no formal distinction between a pointer and an integer (index) in the range <math>[0, N]</math>. A data structure is then implicit, if the only such integer which need be retained is ''N'' itself.", p. 238</ref> या अधिक शिथिल रूप से निरंतर ओवरहेड के साथ डेटा संरचना के रूप में ({{math|''O''(1)}}).<ref>"... one might prefer to permit a constant number of pointers to be retained and still designate the structure as implicit.", p. 238</ref> यह बाद वाली परिभाषा आज अधिक मानक है, और गैर-स्थिर लेकिन छोटी डेटा संरचना की अभी भी ढीली धारणा है {{math|''o''(n)}} ओवरहेड को आज संक्षिप्त डेटा संरचना के रूप में जाना जाता है, जैसा कि परिभाषित किया गया है {{harvtxt|Jacobson|1988}}; इसे अर्ध-अंतर्निहित के रूप में संदर्भित किया गया था {{harvtxt|Munro|Suwanda|1980}}.<ref>"We will also suggest two structures which might be described as “semi-implicit,” in that a variable, but ''o''(''N''), number of pointers (indices) is kept.", p. 238</ref>
ऐतिहासिक रूप से, {{harvtxt|मुनरो|सुवांडा|1980}} ने अंतर्निहित डेटा संरचना (और पर कार्य करने वाले एल्गोरिदम) को ऐसी संरचना के रूप में परिभाषित किया है जिसमें संरचनात्मक जानकारी पॉइंटर्स में स्पष्ट होने के अतिरिक्त डेटा संग्रहीत करने के विधियां में अंतर्निहित होती है। वे परिभाषा में कुछ सीमा तक अस्पष्ट हैं, इसे सबसे सख्ती से एकल सरणी के रूप में परिभाषित करते हैं, जिसमें केवल आकार बनाये(ओवरहेड की एकल संख्या) रखा जाता है,<ref>"Thus, only a simple array is needed for the data.", p. 236; "We will draw no formal distinction between a pointer and an integer (index) in the range <math>[0, N]</math>. A data structure is then implicit, if the only such integer which need be retained is ''N'' itself.", p. 238</ref> या निरंतर ओवरहेड ({{math|''O''(1)}}) के साथ डेटा संरचना के रूप में अधिक शिथिल होता है।<ref>"... one might prefer to permit a constant number of pointers to be retained and still designate the structure as implicit.", p. 238</ref> यह बाद वाली परिभाषा आज अधिक मानक है, और गैर-स्थिर लेकिन छोटे {{math|''o''(n)}} ओवरहेड के साथ डेटा संरचना की अभी भी शिथिल धारणा को आज एक संक्षिप्त डेटा संरचना के रूप में जाना जाता है, जैसा कि {{harvtxt|जैकबसन|1988}} द्वारा परिभाषित किया गया है; {{harvtxt|मुनरो|सुवांडा|1980}} द्वारा इसे अर्ध-अंतर्निहित कहा गया था।<ref>"We will also suggest two structures which might be described as “semi-implicit,” in that a variable, but ''o''(''N''), number of pointers (indices) is kept.", p. 238</ref>
स्थैतिक डेटा संरचना (केवल पढ़ने के लिए) और गतिशीलता (जिसे संशोधित किया जा सकता है) के बीच बुनियादी अंतर है। सरल अंतर्निहित डेटा संरचनाएं, जैसे कि क्रमबद्ध सूची को सरणी के रूप में प्रस्तुत करना, स्थिर डेटा संरचना के रूप में बहुत कुशल हो सकता है, लेकिन गतिशील डेटा संरचना के रूप में अक्षम, संशोधन संचालन (जैसे कि क्रमबद्ध सूची के मामले में सम्मिलन) के कारण अकुशल.
 
स्थैतिक डेटा संरचनाओं (केवल पढ़ने के लिए) और गतिशीलता (जिसे संशोधित किया जा सकता है) के बीच मूल अंतर है। सरल अंतर्निहित डेटा संरचनाएं, जैसे कि क्रमबद्ध सूची को सरणी के रूप में प्रस्तुत करना, स्थिर डेटा संरचना के रूप में बहुत कुशल हो सकता है, किन्तु गतिशील डेटा संरचना के रूप में अक्षम, क्योंकि संशोधन संचालन (जैसे कि क्रमबद्ध सूची के स्थिति में सम्मिलन) के कारण अकुशल है।


== उदाहरण ==
== उदाहरण ==
अंतर्निहित डेटा संरचना का तुच्छ उदाहरण [[सरणी डेटा संरचना]] है, जो सूची (अमूर्त डेटा प्रकार) के लिए अंतर्निहित डेटा संरचना है, और केवल लंबाई के निरंतर ओवरहेड की आवश्यकता होती है; [[लिंक्ड सूची]] के विपरीत, जिसमें प्रत्येक डेटा तत्व के साथ सूचक जुड़ा होता है, जो स्पष्ट रूप से तत्व से दूसरे तक संबंध बताता है। इसी तरह, एक [[ शून्य-समाप्त स्ट्रिंग ]] [[स्ट्रिंग (कंप्यूटर विज्ञान)]] (वर्णों की सूची) के लिए अंतर्निहित डेटा संरचना है। इन्हें बहुत सरल माना जाता है क्योंकि ये स्थिर डेटा संरचनाएं (केवल पढ़ने के लिए) हैं, और केवल तत्वों पर पुनरावृत्ति के सरल संचालन को स्वीकार करते हैं।
अंतर्निहित डेटा संरचना का तुच्छ उदाहरण [[सरणी डेटा संरचना]] है, जो सूची (अमूर्त डेटा प्रकार) के लिए अंतर्निहित डेटा संरचना है, और केवल लंबाई के निरंतर ओवरहेड की आवश्यकता होती है; [[लिंक्ड सूची]] के विपरीत, जिसमें प्रत्येक डेटा तत्व के साथ सूचक जुड़ा होता है, जो स्पष्ट रूप से तत्व से दूसरे तक संबंध बताता है। इसी तरह, एक [[ शून्य-समाप्त स्ट्रिंग |शून्य-समाप्त स्ट्रिंग]] [[स्ट्रिंग (कंप्यूटर विज्ञान)]] (वर्णों की सूची) के लिए अंतर्निहित डेटा संरचना है। इन्हें बहुत सरल माना जाता है क्योंकि ये स्थिर डेटा संरचनाएं (केवल पढ़ने के लिए) हैं, और केवल तत्वों पर पुनरावृत्ति के सरल संचालन को स्वीकार करते हैं।


इसी तरह सरल बहु-आयामी सरणी को उसके आयामों के साथ एकल 1-आयामी सरणी के रूप में प्रस्तुत करना है। उदाहरण के लिए, m × n सरणी को लंबाई m·n की एकल सूची के रूप में प्रस्तुत करना, संख्याओं m और n के साथ (प्रत्येक 1-आयामी उपसरणी के लिए पॉइंटर्स की 1-आयामी सरणी के बजाय)तत्वों को ही प्रकार का होना जरूरी नहीं है, और डेटा की [[तालिका (जानकारी)]] ([[रिकॉर्ड (कंप्यूटर विज्ञान)]] की सूची) को प्रत्येक फ़ील्ड की लंबाई के साथ, फ्लैट (1-आयामी) सूची के रूप में दर्शाया जा सकता है। (कंप्यूटर विज्ञान), जब तक कि प्रत्येक फ़ील्ड का आकार समान हो (इसलिए प्रति फ़ील्ड ही आकार का उपयोग किया जा सकता है, प्रति रिकॉर्ड नहीं)।
इसी प्रकार सरल बहु-आयामी सरणी को उसके आयामों के साथ एकल 1-आयामी सरणी के रूप में प्रस्तुत करना है। उदाहरण के लिए, m × n सरणी को संख्याओं m और n के साथ (प्रत्येक 1-आयामी उपसरणी के लिए पॉइंटर्स की 1-आयामी सरणी के अतिरिक्त) लंबाई m·n की एकल सूची के रूप में प्रस्तुत करना है। तत्वों को ही प्रकार का होना आवश्यक नहीं है, और डेटा की [[तालिका (जानकारी)]] ([[रिकॉर्ड (कंप्यूटर विज्ञान)]] की सूची) को प्रत्येक फ़ील्ड की लंबाई के साथ, फ्लैट (1-आयामी) सूची के रूप में दर्शाया जा सकता है। (कंप्यूटर विज्ञान), जब तक कि प्रत्येक फ़ील्ड का आकार समान हो (जिससे प्रति रिकॉर्ड नहीं चूंकि प्रति फ़ील्ड एक ही आकार का उपयोग किया जा सके)।


कम तुच्छ उदाहरण [[क्रमबद्ध सरणी]] द्वारा क्रमबद्ध सूची का प्रतिनिधित्व कर रहा है, जो बाइनरी खोज द्वारा लघुगणकीय समय में खोज की अनुमति देता है। [[खोज वृक्ष]] के साथ तुलना करें, विशेष रूप से [[द्विआधारी खोज]] वृक्ष, जो लघुगणक-समय खोज की भी अनुमति देता है, लेकिन इसके लिए पॉइंटर्स की आवश्यकता होती है। क्रमबद्ध सरणी केवल स्थिर डेटा संरचना के रूप में ही कुशल है, क्योंकि सूची को संशोधित करना धीमा है - [[बाइनरी सर्च ट्री]] के विपरीत - लेकिन इसके लिए ट्री के ओवरहेड स्थान की आवश्यकता नहीं होती है।
कम तुच्छ उदाहरण [[क्रमबद्ध सरणी]] द्वारा क्रमबद्ध सूची का प्रतिनिधित्व कर रहा है, जो बाइनरी खोज द्वारा लघुगणकीय समय में खोज की अनुमति देता है। [[खोज वृक्ष|खोज ट्री]] के साथ तुलना करें, विशेष रूप से [[द्विआधारी खोज|बाइनरी खोज]] ट्री, जो लघुगणक-समय खोज की भी अनुमति देता है, किन्तु इसके लिए पॉइंटर्स की आवश्यकता होती है। क्रमबद्ध सरणी केवल स्थिर डेटा संरचना के रूप में ही कुशल है, क्योंकि सूची को संशोधित करना धीमा है - [[बाइनरी सर्च ट्री]] के विपरीत - किन्तु इसके लिए ट्री के ओवरहेड स्थान की आवश्यकता नहीं होती है।


अंतर्निहित डेटा संरचना का महत्वपूर्ण उदाहरण गहराई के बढ़ते क्रम में [[पूरा बाइनरी ट्री]] को सूची के रूप में प्रस्तुत करना है, जैसे रूट, पहला बायां बच्चा, पहला दायां बच्चा, पहले बाएं बच्चे का पहला बायां बच्चा, आदि। ऐसा पेड़ उल्लेखनीय रूप से होता है किसी दिए गए गहराई तक वंश चार्ट के लिए, और अंतर्निहित प्रतिनिधित्व को [[वंशावली]] (पूर्वज तालिका) के रूप में जाना जाता है।
अंतर्निहित डेटा संरचना का महत्वपूर्ण उदाहरण गहराई के बढ़ते क्रम में [[पूरा बाइनरी ट्री]] को सूची के रूप में प्रस्तुत करना है, जैसे रूट, पहला बायां बच्चा, पहला दायां बच्चा, पहले बाएं बच्चे का पहला बायां बच्चा, आदि। ऐसा ट्री उल्लेखनीय रूप से होता है किसी दिए गए गहराई तक वंश चार्ट के लिए, और अंतर्निहित प्रतिनिधित्व को [[वंशावली|अहनेंटाफेल]] (पूर्वज तालिका) के रूप में जाना जाता है।


इसे [[उत्तम बाइनरी ट्री]] (जहां अंतिम स्तर अधूरा हो सकता है) के लिए सामान्यीकृत किया जा सकता है, जो अंतर्निहित डेटा संरचना का सबसे प्रसिद्ध उदाहरण देता है, अर्थात् [[ बाइनरी ढेर ]], जो [[प्राथमिकता कतार]] के लिए अंतर्निहित डेटा संरचना है। यह पहले के उदाहरणों की तुलना में अधिक परिष्कृत है क्योंकि यह एकाधिक संचालन की अनुमति देता है, और कुशल गतिशील डेटा संरचना है (यह डेटा के कुशल संशोधन की अनुमति देता है): न केवल 'शीर्ष', बल्कि 'सम्मिलित करें' और 'पॉप' भी।
इसे [[उत्तम बाइनरी ट्री|पूर्ण बाइनरी ट्री]] (जहां अंतिम स्तर अधूरा हो सकता है) के लिए सामान्यीकृत किया जा सकता है, जो अंतर्निहित डेटा संरचना का सबसे प्रसिद्ध उदाहरण देता है, अर्थात् [[ बाइनरी ढेर |बाइनरी हीप]] , जो [[प्राथमिकता कतार|प्राथमिकता क्रम]] के लिए अंतर्निहित डेटा संरचना है। यह पहले के उदाहरणों की तुलना में अधिक परिष्कृत है क्योंकि यह एकाधिक संचालन की अनुमति देता है, और एक कुशल गतिशील डेटा संरचना है (यह डेटा के कुशल संशोधन की अनुमति देता है) न केवल शीर्ष पर, किन्तु सम्मिलित और पॉप भी करता है।


अधिक परिष्कृत अंतर्निहित डेटा संरचनाओं में [[बीप]] (द्वि-अभिभावक ढेर) शामिल है।
अधिक परिष्कृत अंतर्निहित डेटा संरचनाओं में [[बीप]] (द्वि-अभिभावक हीप) सम्मिलित है।


== इतिहास ==
== इतिहास ==
सूचियों या मूल्यों की तालिकाओं के तुच्छ उदाहरण प्रागैतिहासिक काल के हैं, जबकि ऐतिहासिक रूप से गैर-तुच्छ अंतर्निहित डेटा संरचनाएं कम से कम अहनेंटाफेल की हैं, जिसे वंशावली में उपयोग के लिए 1590 में माइकल एइट्ज़िंगर द्वारा पेश किया गया था। औपचारिक कंप्यूटर विज्ञान में, पहली अंतर्निहित डेटा संरचना को आम तौर पर क्रमबद्ध सूची माना जाता है, जिसका उपयोग बाइनरी खोज के लिए किया जाता है, जिसे 1946 में [[जॉन मौचली]] द्वारा [[मूर स्कूल व्याख्यान]] में पेश किया गया था, जो किसी भी कंप्यूटर से संबंधित व्याख्यान का पहला सेट था। विषय।{{Sfn|Knuth|1998|loc=§6.2.1 ("Searching an ordered table"), subsection "History and bibliography"}}<ref name="FranceschiniMunro2006">{{cite conference |last1=Franceschini |first1=Gianni |last2= Munro |first2=J. Ian |author-link2=Ian Munro (computer scientist) |title=अद्यतन और तेज़ खोज के अनुसार ''ओ''(1) संशोधनों के साथ निहित शब्दकोश|year=2006 |pages=404–413 |conference=Seventeenth Annual ACM-SIAM Symposium on Discrete Algorithms |location=Miami, FL, United States |doi=10.1145/1109557.1109603}}</ref> बाइनरी हीप को पेश किया गया था {{harvtxt|Williams|1964}} [[ढेर बनाएं और छांटें]] को लागू करने के लिए।<ref name="FranceschiniMunro2006"/>अंतर्निहित डेटा संरचना की धारणा को औपचारिक रूप दिया गया था {{harvtxt|Munro|Suwanda|1980}}, बीप का परिचय और विश्लेषण करने के भाग के रूप में।<ref name="FranceschiniMunro2006"/>
सूचियों या मूल्यों की तालिकाओं के तुच्छ उदाहरण प्रागैतिहासिक काल के हैं, जबकि ऐतिहासिक रूप से गैर-तुच्छ अंतर्निहित डेटा संरचनाएं कम से कम अहनेंटाफेल की हैं, जिसे अहनेंटाफेल में उपयोग के लिए 1590 में माइकल एइट्ज़िंगर द्वारा प्रस्तुत किया गया था। औपचारिक कंप्यूटर विज्ञान में, पहली अंतर्निहित डेटा संरचना को सामान्यतः क्रमबद्ध सूची माना जाता है, जिसका उपयोग बाइनरी खोज के लिए किया जाता है, जिसे 1946 में [[जॉन मौचली]] द्वारा [[मूर स्कूल व्याख्यान]] में प्रस्तुत किया गया था, जो किसी भी कंप्यूटर से संबंधित व्याख्यान का पहला सेट था। विषय।{{Sfn|Knuth|1998|loc=§6.2.1 ("Searching an ordered table"), subsection "History and bibliography"}}<ref name="FranceschiniMunro2006">{{cite conference |last1=Franceschini |first1=Gianni |last2= Munro |first2=J. Ian |author-link2=Ian Munro (computer scientist) |title=अद्यतन और तेज़ खोज के अनुसार ''ओ''(1) संशोधनों के साथ निहित शब्दकोश|year=2006 |pages=404–413 |conference=Seventeenth Annual ACM-SIAM Symposium on Discrete Algorithms |location=Miami, FL, United States |doi=10.1145/1109557.1109603}}</ref> हीप्सॉर्ट को लागू करने के लिए बाइनरी [[ढेर बनाएं और छांटें|हीप]] को {{harvtxt|विलियम्स|1964}} में प्रस्तुत किया गया था।<ref name="FranceschiniMunro2006"/> बीप को प्रस्तुत करने और उसका विश्लेषण करने के हिस्से के रूप में, {{harvtxt|मुनरो|सुवांडा|1980}} में एक अंतर्निहित डेटा संरचना की धारणा को औपचारिक रूप दिया गया था।<ref name="FranceschiniMunro2006"/>




Line 41: Line 42:
== अग्रिम पठन ==
== अग्रिम पठन ==
See publications of [https://web.archive.org/web/20051217162328/http://photon.poly.edu/~hbr/ Hervé Brönnimann], [[J. Ian Munro]], and [http://www.cs.purdue.edu/people/gnf Greg Frederickson].
See publications of [https://web.archive.org/web/20051217162328/http://photon.poly.edu/~hbr/ Hervé Brönnimann], [[J. Ian Munro]], and [http://www.cs.purdue.edu/people/gnf Greg Frederickson].
[[Category: डेटा संरचनाएं]]


[[Category: Machine Translated Page]]
[[Category:Created On 10/07/2023]]
[[Category:Created On 10/07/2023]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Templates Vigyan Ready]]
[[Category:डेटा संरचनाएं]]

Latest revision as of 15:09, 28 July 2023

कंप्यूटर विज्ञान में, अंतर्निहित डेटा संरचना या स्पेस-कुशल डेटा संरचना एक डेटा संरचना है जो मुख्य या आवश्यक डेटा के अतिरिक्त बहुत कम जानकारी संग्रहीत करती है: डेटा संरचना जिसके लिए कम ओवरहेड (कंप्यूटिंग) की आवश्यकता होती है। उन्हें अंतर्निहित कहा जाता है क्योंकि तत्वों की स्थिति तत्वों के बीच अर्थ और संबंध रखती है; यह तत्वों के बीच स्पष्ट संबंध देने के लिए पॉइंटर (कंप्यूटर विज्ञान) के उपयोग से इसकी तुलना की जाती है। कम ओवरहेड की परिभाषाएँ अलग-अलग होती हैं, किन्तु सामान्यतः बड़े O नोटेशन, O(1) ओवरहेड में इसका अर्थ निरंतर ओवरहेड होता है। एक कम प्रतिबंधात्मक परिभाषा एक संक्षिप्त डेटा संरचना है, जो अधिक ओवरहेड की अनुमति देती है।

परिभाषा

अंतर्निहित डेटा संरचना O(1) स्पेस ओवरहेड (सूचना-सैद्धांतिक निचली सीमा के ऊपर) स्थिरांक वाली होती है।

ऐतिहासिक रूप से, मुनरो & सुवांडा (1980) ने अंतर्निहित डेटा संरचना (और पर कार्य करने वाले एल्गोरिदम) को ऐसी संरचना के रूप में परिभाषित किया है जिसमें संरचनात्मक जानकारी पॉइंटर्स में स्पष्ट होने के अतिरिक्त डेटा संग्रहीत करने के विधियां में अंतर्निहित होती है। वे परिभाषा में कुछ सीमा तक अस्पष्ट हैं, इसे सबसे सख्ती से एकल सरणी के रूप में परिभाषित करते हैं, जिसमें केवल आकार बनाये(ओवरहेड की एकल संख्या) रखा जाता है,[1] या निरंतर ओवरहेड (O(1)) के साथ डेटा संरचना के रूप में अधिक शिथिल होता है।[2] यह बाद वाली परिभाषा आज अधिक मानक है, और गैर-स्थिर लेकिन छोटे o(n) ओवरहेड के साथ डेटा संरचना की अभी भी शिथिल धारणा को आज एक संक्षिप्त डेटा संरचना के रूप में जाना जाता है, जैसा कि जैकबसन (1988) द्वारा परिभाषित किया गया है; मुनरो & सुवांडा (1980) द्वारा इसे अर्ध-अंतर्निहित कहा गया था।[3]

स्थैतिक डेटा संरचनाओं (केवल पढ़ने के लिए) और गतिशीलता (जिसे संशोधित किया जा सकता है) के बीच मूल अंतर है। सरल अंतर्निहित डेटा संरचनाएं, जैसे कि क्रमबद्ध सूची को सरणी के रूप में प्रस्तुत करना, स्थिर डेटा संरचना के रूप में बहुत कुशल हो सकता है, किन्तु गतिशील डेटा संरचना के रूप में अक्षम, क्योंकि संशोधन संचालन (जैसे कि क्रमबद्ध सूची के स्थिति में सम्मिलन) के कारण अकुशल है।

उदाहरण

अंतर्निहित डेटा संरचना का तुच्छ उदाहरण सरणी डेटा संरचना है, जो सूची (अमूर्त डेटा प्रकार) के लिए अंतर्निहित डेटा संरचना है, और केवल लंबाई के निरंतर ओवरहेड की आवश्यकता होती है; लिंक्ड सूची के विपरीत, जिसमें प्रत्येक डेटा तत्व के साथ सूचक जुड़ा होता है, जो स्पष्ट रूप से तत्व से दूसरे तक संबंध बताता है। इसी तरह, एक शून्य-समाप्त स्ट्रिंग स्ट्रिंग (कंप्यूटर विज्ञान) (वर्णों की सूची) के लिए अंतर्निहित डेटा संरचना है। इन्हें बहुत सरल माना जाता है क्योंकि ये स्थिर डेटा संरचनाएं (केवल पढ़ने के लिए) हैं, और केवल तत्वों पर पुनरावृत्ति के सरल संचालन को स्वीकार करते हैं।

इसी प्रकार सरल बहु-आयामी सरणी को उसके आयामों के साथ एकल 1-आयामी सरणी के रूप में प्रस्तुत करना है। उदाहरण के लिए, m × n सरणी को संख्याओं m और n के साथ (प्रत्येक 1-आयामी उपसरणी के लिए पॉइंटर्स की 1-आयामी सरणी के अतिरिक्त) लंबाई m·n की एकल सूची के रूप में प्रस्तुत करना है। तत्वों को ही प्रकार का होना आवश्यक नहीं है, और डेटा की तालिका (जानकारी) (रिकॉर्ड (कंप्यूटर विज्ञान) की सूची) को प्रत्येक फ़ील्ड की लंबाई के साथ, फ्लैट (1-आयामी) सूची के रूप में दर्शाया जा सकता है। (कंप्यूटर विज्ञान), जब तक कि प्रत्येक फ़ील्ड का आकार समान हो (जिससे प्रति रिकॉर्ड नहीं चूंकि प्रति फ़ील्ड एक ही आकार का उपयोग किया जा सके)।

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

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

इसे पूर्ण बाइनरी ट्री (जहां अंतिम स्तर अधूरा हो सकता है) के लिए सामान्यीकृत किया जा सकता है, जो अंतर्निहित डेटा संरचना का सबसे प्रसिद्ध उदाहरण देता है, अर्थात् बाइनरी हीप , जो प्राथमिकता क्रम के लिए अंतर्निहित डेटा संरचना है। यह पहले के उदाहरणों की तुलना में अधिक परिष्कृत है क्योंकि यह एकाधिक संचालन की अनुमति देता है, और एक कुशल गतिशील डेटा संरचना है (यह डेटा के कुशल संशोधन की अनुमति देता है) न केवल शीर्ष पर, किन्तु सम्मिलित और पॉप भी करता है।

अधिक परिष्कृत अंतर्निहित डेटा संरचनाओं में बीप (द्वि-अभिभावक हीप) सम्मिलित है।

इतिहास

सूचियों या मूल्यों की तालिकाओं के तुच्छ उदाहरण प्रागैतिहासिक काल के हैं, जबकि ऐतिहासिक रूप से गैर-तुच्छ अंतर्निहित डेटा संरचनाएं कम से कम अहनेंटाफेल की हैं, जिसे अहनेंटाफेल में उपयोग के लिए 1590 में माइकल एइट्ज़िंगर द्वारा प्रस्तुत किया गया था। औपचारिक कंप्यूटर विज्ञान में, पहली अंतर्निहित डेटा संरचना को सामान्यतः क्रमबद्ध सूची माना जाता है, जिसका उपयोग बाइनरी खोज के लिए किया जाता है, जिसे 1946 में जॉन मौचली द्वारा मूर स्कूल व्याख्यान में प्रस्तुत किया गया था, जो किसी भी कंप्यूटर से संबंधित व्याख्यान का पहला सेट था। विषय।[4][5] हीप्सॉर्ट को लागू करने के लिए बाइनरी हीप को विलियम्स (1964) में प्रस्तुत किया गया था।[5] बीप को प्रस्तुत करने और उसका विश्लेषण करने के हिस्से के रूप में, मुनरो & सुवांडा (1980) में एक अंतर्निहित डेटा संरचना की धारणा को औपचारिक रूप दिया गया था।[5]


संदर्भ

  1. "Thus, only a simple array is needed for the data.", p. 236; "We will draw no formal distinction between a pointer and an integer (index) in the range . A data structure is then implicit, if the only such integer which need be retained is N itself.", p. 238
  2. "... one might prefer to permit a constant number of pointers to be retained and still designate the structure as implicit.", p. 238
  3. "We will also suggest two structures which might be described as “semi-implicit,” in that a variable, but o(N), number of pointers (indices) is kept.", p. 238
  4. Knuth 1998, §6.2.1 ("Searching an ordered table"), subsection "History and bibliography".
  5. 5.0 5.1 5.2 Franceschini, Gianni; Munro, J. Ian (2006). अद्यतन और तेज़ खोज के अनुसार (1) संशोधनों के साथ निहित शब्दकोश. Seventeenth Annual ACM-SIAM Symposium on Discrete Algorithms. Miami, FL, United States. pp. 404–413. doi:10.1145/1109557.1109603.


अग्रिम पठन

See publications of Hervé Brönnimann, J. Ian Munro, and Greg Frederickson.