पायथन - पुनरावृत्ति

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

Recursion का उपयोग करके बाइनरी सर्च

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

def bsearch(list, idx0, idxn, val):

    if (idxn < idx0):
        return None
    else:
        midval = idx0 + ((idxn - idx0) // 2)
# Compare the search item with middle most value

        if list[midval] > val:
            return bsearch(list, idx0, midval-1,val)
        elif list[midval] < val:
            return bsearch(list, midval+1, idxn, val)
        else:
            return midval

list = [8,11,24,56,88,131]
print(bsearch(list, 0, 5, 24))
print(bsearch(list, 0, 5, 51))

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

2
None