⊗pyPmFnRe 24 of 129 menu

पायथन में रिकर्सन

प्रोग्रामिंग में एक ऐसी अवधारणा है, जिसे रिकर्सन कहा जाता है - जब कोई फ़ंक्शन स्वयं को कॉल करता है।

उदाहरण . काउंटर के साथ सरल रिकर्सन

आइए रिकर्सन का उपयोग करके 1 से 10 तक की संख्याएँ प्रिंट करें:

i = 1 def func(): global i print(i) i += 1 if i <= 10: func() # यहाँ फ़ंक्शन स्वयं को कॉल करता है func()

आइए चर्चा करें कि यह कोड कैसे काम करता है।

हमारे पास एक ग्लोबल वेरिएबल i और एक फ़ंक्शन func है, जिसके अंदर वेरिएबल i की वैल्यू को कंसोल में प्रिंट किया जाता है, और फिर उसमें एक जोड़ दिया जाता है।

यदि हमारा वेरिएबल i, 10 से कम या बराबर है, तो फ़ंक्शन को दोबारा कॉल किया जाता है। चूंकि वेरिएबल i - ग्लोबल है, तो फ़ंक्शन के हर नए कॉल पर इसमें पिछले कॉल में सेट की गई i वेरिएबल की वैल्यू होगी।

ऐसा होगा कि फ़ंक्शन तब तक स्वयं को कॉल करता रहेगा, जब तक कि i, 10 से अधिक नहीं हो जाता।

ध्यान रखें, हमारे मामले में if के बिना फ़ंक्शन को नहीं चलाया जा सकता - यदि ऐसा किया जाता है, तो फ़ंक्शन का अनंत कॉल होगा।

उदाहरण . नेस्टेड लिस्ट के एलिमेंट्स प्रिंट करने के लिए रिकर्सन

रिकर्सन का सबसे अधिक उपयोग विभिन्न स्तरों की नेस्टेड लिस्ट को इटरेट करने के लिए किया जाता है। मान लीजिए हमारे पास निम्नलिखित लिस्ट है:

lst = [1, [2, 3], [[4, 5], [6, 7, 8, [9]]]]

आइए एक ऐसा फ़ंक्शन बनाएं जो इसे इटरेट करे। इसमें पहले एक कंडीशन सेट करनी होगी, ताकि प्रिमिटिव एलिमेंट, यानी लिस्ट से निकाला गया साधारण नंबर, कंसोल में प्रिंट हो जाए। और यदि एलिमेंट एक ऑब्जेक्ट है, उदाहरण के लिए एक नेस्टेड लिस्ट, तो इस केस में फ़ंक्शन स्वयं को कॉल करे, यानी रिकर्सन हो। एलिमेंट के टाइप की जांच के लिए हम isinstance फ़ंक्शन का उपयोग करेंगे। केवल हमारे उदाहरण के लिए isinstance के पहले पैरामीटर में हम el लिखेंगे, और दूसरे में टाइप list:

def func(lst): for el in lst: if isinstance(el, list): func(el) else: print(el)

फ़ंक्शन को कॉल करने पर नेस्टेड लिस्ट के सभी नंबरों की श्रृंखला प्रिंट होगी:

func(lst) # 1, 2, ... 8, 9 प्रिंट करेगा

उदाहरण . नेस्टेड लिस्ट के एलिमेंट्स के साथ ऑपरेशन के लिए रिकर्सन

रिकर्सन का उपयोग नेस्टेड लिस्ट के एलिमेंट्स के साथ विभिन्न ऑपरेशन के लिए भी किया जा सकता है। मान लीजिए हमारे पास निम्नलिखित लिस्ट है:

lst = [1, [2, 3], [[4, 5], [6, 7, 8, [9]]]]

आइए इसके सभी एलिमेंट्स का योग प्राप्त करें। इसके लिए फ़ंक्शन के अंदर एक वेरिएबल res डिक्लेयर करेंगे, जिसमें नंबरों का योग जमा होगा। कंडीशन में लिखेंगे कि यदि एलिमेंट एक कॉम्प्लेक्स ऑब्जेक्ट है, तो वह func फ़ंक्शन के पैरामीटर में आएगा और योग में जुड़ जाएगा। इसका मतलब है कि एलिमेंट रिकर्सन में तब तक रहेगा जब तक वह प्रिमिटिव नहीं बन जाता। और इस केस में वह सीधे res में लिखे योग में जुड़ जाएगा:

def func(lst): res = 0 for el in lst: if isinstance(el, list): res += func(el) else: res += el return res

आइए फ़ंक्शन को कॉल करें और इसके रिजल्ट को कंसोल में प्रिंट करें:

print(func(lst)) # 45 प्रिंट करेगा

उदाहरण . लिस्ट में जमा करने के लिए रिकर्सन

रिकर्सन की मदद से नेस्टेड लिस्ट को एक वन-डायमेंशनल लिस्ट में बदला जा सकता है। मान लीजिए हमारे पास निम्नलिखित लिस्ट है:

lst = [1, [2, 3], [[4, 5], [6, 7, 8, [9]]]]

आइए फ़ंक्शन में एक खाली लिस्ट res लिखें, जिसमें सोर्स लिस्ट के एलिमेंट्स जमा होंगे। इसके बाद एक लूप चलाएंगे और एक कंडीशन सेट करेंगे - यदि एलिमेंट एक लिस्ट है, तो वह extend मेथड में जाएगा। यह मेथड एक लिस्ट के एलिमेंट्स को दूसरी लिस्ट के अंत में जोड़ता है, यानी नेस्टेड लिस्ट के एलिमेंट res लिस्ट के अंत में चले जाएंगे:

def func(lst): res = [] for el in lst: if isinstance(el, list): res.extend(func(el)) else: res.append(el) return res print(func(lst))

निष्पादित कोड का परिणाम:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

प्रैक्टिकल टास्क

एक मनमाना लेवल की नेस्टिंग वाले डिक्शनरी के सभी न्यूमेरिक एलिमेंट्स प्रिंट करें:

{ 'a': { 'b': 1, 'c': 2, 'd': { 'e': 3, 'f': 4 } }, 'j': { 'h': 5, 'k': 6, }, 'l': 7 }

पिछली टास्क के डिक्शनरी के एलिमेंट्स का योग ज्ञात करें।

पिछली टास्क के डिक्शनरी के प्रिमिटिव एलिमेंट्स की लिस्ट प्राप्त करें।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें