इंडेक्स मैपिंग: Difference between revisions
m (Deepak moved page सूचकांक मानचित्रण to इंडेक्स मैपिंग without leaving a redirect) |
No edit summary |
||
Line 1: | Line 1: | ||
{{distinguish|text=[[Index map]], a finding aid in cartography}} | {{distinguish|text=[[Index map]], a finding aid in cartography}} | ||
[[कंप्यूटर विज्ञान]] में इंडेक्स मैपिंग (या डायरेक्ट एड्रेसिंग, या | [[कंप्यूटर विज्ञान]] में इंडेक्स मैपिंग (या डायरेक्ट एड्रेसिंग, या तुच्छ [[हैश फंकशन]]) [[सरणी डेटा संरचना]] का उपयोग करने का वर्णन करता है, जिसमें प्रत्येक स्थिति संभावित मूल्यों के [[ब्रह्मांड (गणित)]] में कुंजी से मेल खाती है।<ref name=cormen>{{cite book|last1=Cormen|first1=Thomas H.|title=एल्गोरिदम का परिचय|date=2009|publisher=MIT Press|location=Cambridge, Mass.|isbn=9780262033848|pages=253–255|edition=3rd|url=https://mitpress.mit.edu/books/introduction-algorithms|accessdate=26 November 2015}}</ref> | ||
तकनीक तब सबसे प्रभावी होती है जब कुंजियों का ब्रह्मांड यथोचित रूप से छोटा होता है, जैसे कि प्रत्येक संभावित कुंजी के लिए | तकनीक तब सबसे प्रभावी होती है जब कुंजियों का ब्रह्मांड यथोचित रूप से छोटा होता है, जैसे कि प्रत्येक संभावित कुंजी के लिए स्थिति के साथ सरणी का मेमोरी आवंटन किफायती होता है।इसकी प्रभावशीलता इस तथ्य से आती है कि किसी सरणी में मनमानी स्थिति की जांच समय जटिलता#स्थिर समय में की जा सकती है। | ||
==लागू सरणियाँ== | ==लागू सरणियाँ== | ||
डेटा के कई व्यावहारिक उदाहरण हैं जिनके वैध मान | डेटा के कई व्यावहारिक उदाहरण हैं जिनके वैध मान छोटी सीमा के भीतर प्रतिबंधित हैं। जब ऐसे डेटा को लुकअप कुंजी के रूप में कार्य करने की आवश्यकता होती है तो तुच्छ हैश फ़ंक्शन उपयुक्त विकल्प है। कुछ उदाहरणों में शामिल हैं: | ||
*वर्ष में [[महीना]] (1-12) | *वर्ष में [[महीना]] (1-12) | ||
* महीने में [[दिन]] (1-31) | * महीने में [[दिन]] (1-31) | ||
*[[सप्ताह का दिन]] (1-7) | *[[सप्ताह का दिन]] (1-7) | ||
*मानव आयु (0-130)-उदा. लाइफकवर | *मानव आयु (0-130)-उदा. लाइफकवर ्चुअरी टेबल, निश्चित अवधि बंधक | ||
* [[ASCII]] वर्ण (0-127), जिसमें सामान्य गणितीय ऑपरेटर प्रतीक, अंक, विराम चिह्न और अंग्रेजी भाषा वर्णमाला शामिल हैं | * [[ASCII]] वर्ण (0-127), जिसमें सामान्य गणितीय ऑपरेटर प्रतीक, अंक, विराम चिह्न और अंग्रेजी भाषा वर्णमाला शामिल हैं | ||
==उदाहरण== | ==उदाहरण== | ||
गैर-पुनरावृत्तीय तालिका लुकअप में, तुच्छ हैश फ़ंक्शन का उपयोग करके, सशर्त परीक्षण और शाखाकरण को पूरी तरह से समाप्त किया जा सकता है, जिससे कंप्यूटर प्रोग्राम की निर्देश पथ लंबाई कम हो सकती है। | |||
===शाखा लगाने से बचें=== | ===शाखा लगाने से बचें=== | ||
रोजर सैले | रोजर सैले उदाहरण देते हैं<ref>{{cite journal|last1=Sayle|first1=Roger Anthony|title=मल्टीवे ब्रांच कोड जनरेशन का एक सुपरऑप्टिमाइज़र विश्लेषण|journal=Proceedings of the GCC Developers' Summit|date=June 17, 2008|pages=103–116|url=https://www.nextmovesoftware.com/technology/SwitchOptimization.pdf|accessdate=26 November 2015}}</ref> [[ स्विच कथन ]] के कारण होने वाली [[मल्टीवे शाखा]] को समाप्त करना: | ||
<सिंटैक्सहाइलाइट लैंग= सी++ > | <सिंटैक्सहाइलाइट लैंग= सी++ > |
Revision as of 23:42, 4 August 2023
कंप्यूटर विज्ञान में इंडेक्स मैपिंग (या डायरेक्ट एड्रेसिंग, या तुच्छ हैश फंकशन) सरणी डेटा संरचना का उपयोग करने का वर्णन करता है, जिसमें प्रत्येक स्थिति संभावित मूल्यों के ब्रह्मांड (गणित) में कुंजी से मेल खाती है।[1] तकनीक तब सबसे प्रभावी होती है जब कुंजियों का ब्रह्मांड यथोचित रूप से छोटा होता है, जैसे कि प्रत्येक संभावित कुंजी के लिए स्थिति के साथ सरणी का मेमोरी आवंटन किफायती होता है।इसकी प्रभावशीलता इस तथ्य से आती है कि किसी सरणी में मनमानी स्थिति की जांच समय जटिलता#स्थिर समय में की जा सकती है।
लागू सरणियाँ
डेटा के कई व्यावहारिक उदाहरण हैं जिनके वैध मान छोटी सीमा के भीतर प्रतिबंधित हैं। जब ऐसे डेटा को लुकअप कुंजी के रूप में कार्य करने की आवश्यकता होती है तो तुच्छ हैश फ़ंक्शन उपयुक्त विकल्प है। कुछ उदाहरणों में शामिल हैं:
- वर्ष में महीना (1-12)
- महीने में दिन (1-31)
- सप्ताह का दिन (1-7)
- मानव आयु (0-130)-उदा. लाइफकवर ्चुअरी टेबल, निश्चित अवधि बंधक
- ASCII वर्ण (0-127), जिसमें सामान्य गणितीय ऑपरेटर प्रतीक, अंक, विराम चिह्न और अंग्रेजी भाषा वर्णमाला शामिल हैं
उदाहरण
गैर-पुनरावृत्तीय तालिका लुकअप में, तुच्छ हैश फ़ंक्शन का उपयोग करके, सशर्त परीक्षण और शाखाकरण को पूरी तरह से समाप्त किया जा सकता है, जिससे कंप्यूटर प्रोग्राम की निर्देश पथ लंबाई कम हो सकती है।
शाखा लगाने से बचें
रोजर सैले उदाहरण देते हैं[2] स्विच कथन के कारण होने वाली मल्टीवे शाखा को समाप्त करना:
<सिंटैक्सहाइलाइट लैंग= सी++ > इनलाइन बूल hasOnly30Days(int m) { स्विच (एम) { केस 4: // अप्रैल केस 6: // जून केस 9: // सितंबर केस 11: // नवंबर सच लौटें; गलती करना: विवरण झूठा है; } } </सिंटैक्सहाइलाइट>
जिसे टेबल लुकअप से बदला जा सकता है:
<सिंटैक्सहाइलाइट लैंग= सी++ > इनलाइन बूल hasOnly30Days(int m) { स्टेटिक कॉन्स्ट बूल टी[] = {0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 }; वापसी टी[एम-1]; } </सिंटैक्सहाइलाइट>
यह भी देखें
संदर्भ
- ↑ Cormen, Thomas H. (2009). एल्गोरिदम का परिचय (3rd ed.). Cambridge, Mass.: MIT Press. pp. 253–255. ISBN 9780262033848. Retrieved 26 November 2015.
- ↑ Sayle, Roger Anthony (June 17, 2008). "मल्टीवे ब्रांच कोड जनरेशन का एक सुपरऑप्टिमाइज़र विश्लेषण" (PDF). Proceedings of the GCC Developers' Summit: 103–116. Retrieved 26 November 2015.