अजगर - खोज एल्गोरिदम

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

रैखिक खोज

इस प्रकार की खोज में, एक के बाद एक सभी वस्तुओं पर अनुक्रमिक खोज की जाती है। प्रत्येक आइटम की जाँच की जाती है और यदि कोई मेल मिलता है तो उस विशेष आइटम को वापस कर दिया जाता है, अन्यथा डेटा संरचना के अंत तक खोज जारी रहती है।

def linear_search(values, search_for):
    search_at = 0
    search_res = False

# Match the value with each data element	
    while search_at < len(values) and search_res is False:
        if values[search_at] == search_for:
            search_res = True
        else:
            search_at = search_at + 1

    return search_res

l = [64, 34, 25, 12, 22, 11, 90]
print(linear_search(l, 12))
print(linear_search(l, 91))

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

True
False

इंटरपोलेशन सर्च

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

मध्य स्थिति की गणना करने के लिए एक विशिष्ट सूत्र है जो नीचे दिए गए कार्यक्रम में इंगित किया गया है।

def intpolsearch(values,x ):
    idx0 = 0
    idxn = (len(values) - 1)

    while idx0 <= idxn and x >= values[idx0] and x <= values[idxn]:

# Find the mid point
	mid = idx0 +\
               int(((float(idxn - idx0)/( values[idxn] - values[idx0]))
                    * ( x - values[idx0])))

# Compare the value at mid point with search value 
        if values[mid] == x:
            return "Found "+str(x)+" at index "+str(mid)

        if values[mid] < x:
            idx0 = mid + 1
    return "Searched element not in the list"


l = [2, 6, 11, 19, 27, 31, 45, 121]
print(intpolsearch(l, 2))

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

Found 2 at index 0