जावामध्ये पुनरावृत्ती - उदाहरणांसह ट्यूटोरियल

जावामधील पुनरावृत्तीवरील हे सखोल ट्यूटोरियल उदाहरणे, प्रकार आणि संबंधित संकल्पनांसह पुनरावृत्ती काय आहे हे स्पष्ट करते. यात पुनरावृत्ती विरुद्ध पुनरावृत्ती देखील समाविष्ट आहे:

आमच्या Java मधील पूर्वीच्या ट्यूटोरियलमधून, आपण पुनरावृत्तीचा दृष्टीकोन पाहिला आहे ज्यामध्ये आपण लूप घोषित करतो आणि नंतर एक घटक घेऊन पुनरावृत्ती पद्धतीने डेटा स्ट्रक्चरमधून मार्ग काढतो. एक वेळ.

आम्ही कंडिशनल फ्लो देखील पाहिला आहे जिथे आम्ही पुन्हा एक लूप व्हेरिएबल ठेवतो आणि लूप व्हेरिएबल कंडिशन पूर्ण करेपर्यंत कोडचा एक भाग पुन्हा करतो. जेव्हा फंक्शन कॉल्सचा विचार केला जातो तेव्हा आम्ही फंक्शन कॉलसाठी पुनरावृत्तीचा दृष्टीकोन देखील शोधला.

0 या ट्युटोरियलमध्ये, आपण प्रोग्रामिंगच्या वेगळ्या पद्धतीवर चर्चा करू. रिकर्सिव्ह अ‍ॅप्रोच.

जावामध्ये रिकर्शन म्हणजे काय?

पुनरावृत्ती ही एक प्रक्रिया आहे ज्याद्वारे फंक्शन किंवा पद्धत स्वतःला पुन्हा पुन्हा कॉल करते. प्रत्यक्ष किंवा अप्रत्यक्षपणे पुन्हा पुन्हा कॉल केलेल्या या फंक्शनला “रिकर्सिव्ह फंक्शन” म्हणतात.

पुनरावृत्ती समजून घेण्यासाठी आपण विविध उदाहरणे पाहू. आता रिकर्शनचा सिंटॅक्स पाहू.

रिकर्सन सिंटॅक्स

कोणतीही पद्धत जी रिकर्शन लागू करते तिचे दोन मूलभूत भाग असतात:

  1. पद्धतीचा कॉल जो स्वतःला रिकर्सिव्ह म्हणू शकतो
  2. एक पूर्वअट जी पुनरावृत्ती थांबवेल.

लक्षात ठेवा की कोणत्याही पुनरावृत्ती पद्धतीसाठी पूर्वअट आवश्यक आहे, जर आम्ही तसे करत नाही. तोडणेपुनरावृत्ती नंतर ते अमर्यादपणे चालू राहील आणि परिणामी स्टॅक ओव्हरफ्लो होईल.

पुनरावृत्तीचे सामान्य वाक्यरचना खालीलप्रमाणे आहे:

methodName (T parameters…) { if (precondition == true) //precondition or base condition { return result; } return methodName (T parameters…); //recursive call } 

लक्षात घ्या की पूर्वस्थिती देखील म्हटले जाते मूळ स्थिती. आम्ही पुढील भागात बेस कंडिशनबद्दल अधिक चर्चा करू.

जावामध्ये रिकर्शन समजून घेणे

या विभागात, आम्ही पुनरावृत्ती प्रक्रिया समजून घेण्याचा प्रयत्न करू आणि ती कशी होते ते पाहू. आपण बेस कंडिशन, स्टॅक ओव्हरफ्लो याविषयी शिकू आणि रिकर्सन आणि इतर तपशिलांसह विशिष्ट समस्या कशी सोडवली जाऊ शकते ते पाहू.

रिकर्सन बेस कंडिशन

रिकर्सिव प्रोग्राम लिहिताना आपण प्रथम बेस केससाठी उपाय द्या. मग आपण लहान समस्यांच्या संदर्भात मोठी समस्या व्यक्त करतो.

उदाहरणार्थ, आपण संख्येच्या फॅक्टोरियलची गणना करण्याची क्लासिक समस्या घेऊ शकतो. n ही संख्या दिल्यास, आपल्याला n द्वारे दर्शविलेले n चे गुणन्य शोधावे लागेल!

आता पुनरावृत्ती वापरून n फॅक्टोरियल (n!) काढण्यासाठी प्रोग्राम लागू करूया.

public class Main{ static int fact(int n) { if (n == 1) // base condition return 1; else return n*fact(n-1); } public static void main(String[] args) { int result = fact(10); System.out.println("10! = " + result); } }

आउटपुट

या प्रोग्रॅममध्ये, आपण पाहू शकतो की कंडिशन (n=1) ही बेस कंडिशन आहे आणि जेव्हा ही कंडिशन गाठली जाते, तेव्हा फंक्शन 1 मिळवते. फंक्शनचा दुसरा भाग म्हणजे रिकर्सिव्ह कॉल. परंतु प्रत्येक वेळी रिकर्सिव्ह पद्धत म्हटल्यावर n 1 ने कमी होते.

अशा प्रकारे आपण असा निष्कर्ष काढू शकतो की शेवटी n चे मूल्य 1 किंवा 1 पेक्षा कमी होईल आणि येथेपॉइंट, मेथड व्हॅल्यू 1 देईल. ही बेस कंडिशन गाठली जाईल आणि फंक्शन थांबेल. लक्षात घ्या की जोपर्यंत n चे मूल्य मूळ स्थितीचे समाधान करते तोपर्यंत काहीही असू शकते.

पुनरावृत्तीचा वापर करून समस्या सोडवणे

पुनरावृत्ती वापरण्यामागील मूळ कल्पना म्हणजे मोठ्या समस्येच्या दृष्टीने व्यक्त करणे. लहान समस्या. तसेच, आम्हाला एक किंवा अधिक बेस कंडिशन जोडणे आवश्यक आहे जेणेकरुन आम्ही पुनरावृत्तीतून बाहेर पडू शकू.

हे आधीच वरील फॅक्टोरियल उदाहरणामध्ये दाखवले आहे. या प्रोग्राममध्ये, आम्ही n फॅक्टोरियल (n!) लहान व्हॅल्यूजच्या संदर्भात व्यक्त केले आणि बेस कंडिशन (n =1) होती जेणेकरून n 1 वर पोहोचल्यावर, आम्ही रिकर्सिव्ह पद्धत सोडू शकतो.

Recursion मध्ये स्टॅक ओव्हरफ्लो एरर

आम्हाला माहीत आहे की जेव्हा कोणतीही पद्धत किंवा फंक्शन कॉल केले जाते, तेव्हा फंक्शनची स्थिती स्टॅकवर संग्रहित केली जाते आणि फंक्शन परत आल्यावर ती पुनर्प्राप्त केली जाते. स्टॅकचा वापर रिकर्सिव्ह पद्धतीसाठी देखील केला जातो.

परंतु पुनरावृत्तीच्या बाबतीत, जर आपण बेस कंडिशन परिभाषित केली नाही किंवा बेस कंडिशन कशीतरी पोहोचली नाही किंवा अंमलात आणली नाही तर समस्या उद्भवू शकते. जर ही परिस्थिती उद्भवली तर स्टॅक ओव्हरफ्लो होऊ शकतो.

फॅक्टोरियल नोटेशनच्या खालील उदाहरणाचा विचार करू या.

येथे आम्ही एक चुकीची बेस कंडिशन दिली आहे, n==100.

public class Main { static int fact(int n) { if (n == 100) // base condition resulting in stack overflow return 1; else return n*fact(n-1); } public static void main(String[] args) { int result = fact(10); System.out.println("10! = " + result); } }

तर जेव्हा n > 100 पद्धत 1 परत करेल परंतु पुनरावृत्ती थांबणार नाही. n चे मूल्य अनिश्चित काळासाठी कमी होत राहीलते थांबवण्यासाठी दुसरी कोणतीही अट नाही. स्टॅक ओव्हरफ्लो होईपर्यंत हे चालू राहील.

दुसरा केस असेल जेव्हा n चे मूल्य 100. या प्रकरणात, तसेच पद्धत कधीही बेस कंडिशन कार्यान्वित करणार नाही आणि परिणामी स्टॅक ओव्हरफ्लो होणार नाही.

Java मधील पुनरावृत्ती उदाहरणे

या विभागात, आम्ही खालील उदाहरणे वापरून अंमलात आणू. पुनरावृत्ती.

#1) फिबोनाची मालिका पुनरावृत्ती वापरून

फिबोनाची मालिका,

1,1,2,3,5,8,13,21, यांनी दिली आहे. 34,55,…

वरील क्रम दर्शवितो की वर्तमान घटक मागील दोन घटकांची बेरीज आहे. तसेच, फिबोनाची मालिकेतील पहिला घटक 1 आहे.

म्हणून सर्वसाधारणपणे जर n ही वर्तमान संख्या असेल, तर ती (n-1) आणि (n-2) च्या बेरजेने दिली जाते. सध्याचा घटक मागील घटकांच्या संदर्भात व्यक्त केला जात असल्याने, आपण पुनरावृत्ती वापरून ही समस्या व्यक्त करू शकतो.

फिबोनाची मालिका कार्यान्वित करण्यासाठी प्रोग्राम खाली दिलेला आहे:

public class Main { //method to calculate fibonacci series static int fibonacci(int n) { if (n = 1) { return n; } return fibonacci(n-1) + fibonacci(n-2); } public static void main(String[] args) { int number = 10; //print first 10 numbers of fibonacci series System.out.println ("Fibonacci Series: First 10 numbers:"); for (int i = 1; i = number; i++) { System.out.print(fibonacci(i) + " "); } } } 

आउटपुट

#2) आवर्तन वापरून संख्या पॅलिंड्रोम आहे का ते तपासा

पॅलिंड्रोम हा एक क्रम आहे जो समान असतो जेव्हा आपण ते डावीकडून उजवीकडे किंवा उजवीकडून डावीकडे वाचा.

121 क्रमांक दिल्यास, जेव्हा आपण ते डावीकडून उजवीकडे आणि उजवीकडून डावीकडे वाचतो तेव्हा ते समान असते. म्हणून १२१ ही संख्या पॅलिंड्रोम आहे.

आणखी एक संख्या घेऊ, १२४२. जेव्हा आपण ती डावीकडून उजवीकडे वाचतो तेव्हा ती १२४२ असते आणि उजवीकडून डावीकडे वाचताना ते २४२१ असे वाचते. त्यामुळे हा पॅलिंड्रोम नाही.

आम्हीसंख्यांचे अंक उलट करून पॅलिंड्रोम प्रोग्राम अंमलात आणा आणि दिलेल्या संख्येची त्याच्या उलट प्रतिनिधित्वाशी पुनरावृत्तीने तुलना करा.

खालील प्रोग्राम पॅलिंड्रोम तपासण्यासाठी प्रोग्राम लागू करतो.

import java.io.*; import java.util.*; public class Main { // check if num contains only one digit public static int oneDigit(int num) { if ((num >= 0) && (num  10)) return 1; else return 0; } //palindrome utility function public static int isPalindrome_util (int num, int revNum) throws Exception { // base condition; return if num=0 if (num == 0) { return revNum; } else { //call utility function recursively revNum = isPalindrome_util(num / 10, revNum); } // Check if first digit of num and revNum are equal if (num % 10 == revNum % 10) { // if yes, revNum will move with num return revNum / 10; } else { // exit throw new Exception(); } } //method to check if a given number is palindrome using palindrome utility function public static int isPalindrome(int num) throws Exception { if (num  0) num = (-num); int revNum = (num); return isPalindrome_util(num, revNum); } public static void main(String args[]) { int n = 1242; try { isPalindrome(n); System.out.println("Yes, the given number " + n + " is a palindrome."); } catch (Exception e) { System.out.println("No, the given number " + n + " is not a palindrome."); } n = 1221; try { isPalindrome(n); System.out.println("Yes, the given number " + n + " is a palindrome."); } catch (Exception e) { System.out.println("No, the given number " + n + " is not a palindrome."); } } }
0 आउटपुट

#3) रिव्हर्स स्ट्रिंग रिकर्शन Java

"हॅलो" स्ट्रिंग दिल्यास आपल्याला ते उलट करावे लागेल जेणेकरून परिणामी स्ट्रिंग “olleH” आहे.

हे पुनरावृत्ती वापरून केले जाते. स्ट्रिंगमधील शेवटच्या वर्णापासून सुरुवात करून, स्ट्रिंगमधील सर्व वर्ण संपेपर्यंत आम्ही प्रत्येक वर्ण आवर्तीपणे मुद्रित करतो.

खालील प्रोग्राम दिलेल्या स्ट्रिंगला उलट करण्यासाठी पुनरावृत्तीचा वापर करतो.

class String_Reverse { //recursive method to reverse a given string void reverseString(String str) { //base condition; return if string is null or with 1 or less character if ((str==null)||(str.length() = 1)) System.out.println(str); else { //recursively print each character in the string from the end System.out.print(str.charAt(str.length()-1)); reverseString(str.substring(0,str.length()-1)); } } } class Main{ public static void main(String[] args) { String inputstr = "SoftwareTestingHelp"; System.out.println("The given string: " + inputstr); String_Reverse obj = new String_Reverse(); System.out.print("The reversed string: "); obj.reverseString(inputstr); } } 

आउटपुट

#4) बायनरी सर्च जावा रिकर्शन

बायनरी सर्च अल्गोरिदम हे सर्चिंगसाठी प्रसिद्ध अल्गोरिदम आहे. या अल्गोरिदममध्ये, n घटकांची क्रमवारी लावलेली अ‍ॅरे दिलेली आहे, आम्ही दिलेल्या मुख्य घटकासाठी हा अ‍ॅरे शोधतो. सुरुवातीला, आम्ही अॅरेचा मध्य घटक शोधून अॅरेला दोन भागांमध्ये विभागतो.

नंतर की मिडच्या आधारावर आपण अॅरेच्या पहिल्या किंवा दुसऱ्या सहामाहीत आमचा शोध मर्यादित करतो. अशा प्रकारे मुख्य घटकांचे स्थान सापडेपर्यंत समान प्रक्रिया पुनरावृत्ती केली जाते.

आम्ही येथे पुनरावृत्ती वापरून हा अल्गोरिदम लागू करू.

import java.util.*; class Binary_Search { // recursive binary search int binarySearch(int numArray[], int left, int right, int key) { if (right >= left) { //calculate mid of the array int mid = left + (right - left) / 2; // if the key is at mid, return mid if (numArray[mid] == key) return mid; // if key  key) return binarySearch(numArray, left, mid - 1, key); // Else recursively search in the right subarray return binarySearch(numArray, mid + 1, right, key); } // no elements in the array, return -1 return -1; } } class Main{ public static void main(String args[]) { Binary_Search ob = new Binary_Search(); //declare and print the array int numArray[] = { 4,6,12,16,22}; System.out.println("The given array : " + Arrays.toString(numArray)); int len = numArray.length; //length of the array int key = 16; //key to be searched int result = ob.binarySearch(numArray, 0, len - 1, key); if (result == -1) System.out.println("Element " + key + " not present"); else System.out.println("Element " + key + " found at index " + result); } } 

आउटपुट

#5) रिकर्शन वापरून अॅरेमध्ये किमान मूल्य शोधा

पुनरावृत्ती वापरून आपण अॅरेमधील किमान मूल्य देखील शोधू शकतो.

दअॅरेमधील किमान मूल्य शोधण्यासाठी जावा प्रोग्राम खाली दिलेला आहे.

import java.util.*; class Main { static int getMin(int numArray[], int i, int n) { //return first element if only one element or minimum of the array elements return (n == 1) ? numArray[i] : Math.min(numArray[i], getMin(numArray,i + 1 , n - 1)); } public static void main(String[] args) { int numArray[] = { 7,32,64,2,10,23 }; System.out.println("Given Array : " + Arrays.toString(numArray)); int n = numArray.length; System.out.print("Minimum element of array: " + getMin(numArray, 0, n) + "\n"); } }

आउटपुट

22>

हे काही आहेत पुनरावृत्तीची उदाहरणे. या उदाहरणांव्यतिरिक्त, सॉफ्टवेअरमधील इतर अनेक समस्या रिकर्सिव्ह तंत्रांचा वापर करून अंमलात आणल्या जाऊ शकतात.

पुनरावृत्तीचे प्रकार

कॉल केव्हा केला जातो यावर आधारित पुनरावृत्ती दोन प्रकारचे असते रिकर्सिव्ह मेथड.

ते आहेत:

#1) टेल रिकर्शन

जेव्हा रिकर्सिव्ह मेथडला कॉल हे शेवटचे स्टेटमेंट असते रिकर्सिव्ह मेथडमध्ये अंमलात आणले जाते, त्याला “टेल रिकर्सन” असे म्हणतात.

टेल रिकर्शनमध्ये, रिकर्सिव्ह कॉल स्टेटमेंट सहसा मेथडच्या रिटर्न स्टेटमेंटसह अंमलात आणले जाते.

द टेल रिकर्सनसाठी सामान्य वाक्यरचना खाली दिली आहे:

methodName ( T parameters…){ { if (base_condition == true) { return result; } return methodName (T parameters …) //tail recursion } 

#2) हेड रिकर्सन

हेड रिकर्सन हा टेल रिकर्शन नसलेला कोणताही रिकर्सिव्ह दृष्टीकोन आहे. त्यामुळे अगदी सामान्य पुनरावृत्ती हे अग्रेड रिकर्शन आहे.

हेड रिकर्जनचे वाक्यरचना खालीलप्रमाणे आहे:

methodName (T parameters…){ if (some_condition == true) { return methodName (T parameters…); } return result; } 

जावा मधील पुनरावृत्ती विरुद्ध पुनरावृत्ती

पुनरावृत्ती पुनरावृत्ती
पुनरावृत्ती ही एक प्रक्रिया आहे जिथे एक पद्धत मूलभूत स्थिती पूर्ण होईपर्यंत वारंवार कॉल करते. पुनरावृत्ती आहे एक प्रक्रिया ज्याद्वारे कोडचा तुकडा ठराविक वेळा किंवा अट पूर्ण होईपर्यंत वारंवार अंमलात आणला जातो.
फंक्शन्ससाठी अनुप्रयोग आहे. लागू आहे लूपसाठी.
साठी चांगले कार्य करतेलहान कोड आकार. मोठ्या कोड आकारासाठी चांगले कार्य करते.
प्रत्येक रिकर्सिव कॉल स्टॅकवर ढकलला जात असल्याने अधिक मेमरी वापरते तुलनेने कमी मेमरी वापरले जाते.
डीबग करणे आणि देखभाल करणे कठीण डीबग करणे आणि देखभाल करणे सोपे
बेस असल्यास स्टॅक ओव्हरफ्लोमध्ये परिणाम होतो स्थिती निर्दिष्ट केलेली नाही किंवा पोहोचली नाही. अनंत कार्यान्वित होऊ शकते परंतु कोणत्याही मेमरी त्रुटीसह अंमलबजावणी थांबवेल
वेळ जटिलता खूप जास्त आहे. वेळेची जटिलता तुलनेने खालच्या बाजूला आहे.

वारंवार विचारले जाणारे प्रश्न

प्रश्न #1) जावामध्ये पुनरावृत्ती कसे कार्य करते?

उत्तर: पुनरावृत्तीमध्ये, बेस कंडिशन पूर्ण होईपर्यंत रिकर्सिव फंक्शन स्वतःला वारंवार कॉल करते. कॉल फंक्शनसाठी मेमरी कॉलिंग फंक्शनसाठी मेमरीच्या शीर्षस्थानी असलेल्या स्टॅकवर ढकलली जाते. प्रत्येक फंक्शन कॉलसाठी, स्थानिक व्हेरिएबल्सची एक वेगळी प्रत तयार केली जाते.

प्र #2) पुनरावर्ती का वापरली जाते?

उत्तर: पुनरावृत्तीचा उपयोग त्या समस्या सोडवण्यासाठी केला जातो ज्यांना लहान समस्यांमध्ये विभागले जाऊ शकते आणि संपूर्ण समस्या एका लहान समस्येच्या संदर्भात व्यक्त केली जाऊ शकते.

आवर्तनाचा वापर त्या समस्यांसाठी देखील केला जातो ज्या खूप लहान आहेत. पुनरावृत्तीचा दृष्टीकोन वापरून निराकरण करण्यासाठी जटिल. ज्या समस्यांसाठी वेळेची जटिलता ही समस्या नाही याशिवाय, पुनरावृत्ती वापरा.

प्र # 3) चे फायदे काय आहेतपुनरावृत्ती?

उत्तर:

पुनरावृत्तीच्या फायद्यांमध्ये हे समाविष्ट आहे:

  1. पुनरावृत्तीमुळे अनावश्यक कॉलिंग कमी होते फंक्शनचे.
  2. पुनरावृत्तीच्या पध्दतीशी तुलना करता पुनरावृत्तीमुळे आम्हाला समस्या सहजपणे सोडवता येतात.

प्र # 4) कोणते चांगले आहे - पुनरावृत्ती किंवा पुनरावृत्ती?2

उत्तर: बेस फंक्शन पूर्ण होईपर्यंत पुनरावृत्ती वारंवार कॉल करते. अशा प्रकारे प्रत्येक फंक्शन कॉलसाठी मेमरी स्टॅकवर ढकलली गेल्याने मेमरी ओव्हरहेड असते.

दुसरीकडे पुनरावृत्तीमध्ये जास्त मेमरी ओव्हरहेड नसते. पुनरावृत्तीची अंमलबजावणी पुनरावृत्तीच्या दृष्टिकोनापेक्षा हळू आहे. पुनरावृत्तीमुळे कोडचा आकार कमी होतो तर पुनरावृत्तीचा दृष्टीकोन कोड मोठा करतो.

प्र # 5) पुनरावृत्तीवर पुनरावृत्तीचे फायदे काय आहेत?

उत्तर:

  • पुनरावर्तन कोड अधिक स्पष्ट आणि लहान बनवते.
  • हनोई टॉवर, झाड यासारख्या समस्यांसाठी पुनरावृत्तीच्या दृष्टिकोनापेक्षा पुनरावृत्ती अधिक चांगली आहे ट्रॅव्हर्सल्स इ.
  • प्रत्येक फंक्शन कॉलची मेमरी स्टॅकवर पुश ऑन असल्याने, रिकर्शन अधिक मेमरी वापरते.
  • पुनरावृत्तीच्या दृष्टिकोनापेक्षा पुनरावृत्ती कार्यप्रदर्शन कमी असते.

निष्कर्ष

प्रोग्रामिंग भाषेची पर्वा न करता सॉफ्टवेअरमध्ये पुनरावृत्ती ही एक अतिशय महत्त्वाची संकल्पना आहे. पुनरावृत्तीचा उपयोग मुख्यतः हनोईचे टॉवर्स, ट्री ट्रॅव्हर्सल्स, लिंक्ड लिस्ट इत्यादी डेटा स्ट्रक्चर समस्या सोडवण्यासाठी केला जातो. जरी यास जास्त मेमरी लागते,रिकर्शन कोड अधिक सोपा आणि स्पष्ट बनवते.

आम्ही या ट्युटोरियलमध्ये रिकर्शन बद्दल सर्व काही शोधले आहे. संकल्पना चांगल्या प्रकारे समजून घेण्यासाठी आम्ही अनेक प्रोग्रामिंग उदाहरणे देखील लागू केली आहेत.

वरील स्क्रॉल करा