ការបង្រៀនស៊ីជម្រៅនេះ ស្តីពីការផ្សាយឡើងវិញនៅក្នុង Java ពន្យល់ពីអ្វីដែលជាការកើតឡើងវិញជាមួយនឹងឧទាហរណ៍ ប្រភេទ និងគំនិតដែលពាក់ព័ន្ធ។ វាក៏គ្របដណ្តប់លើ Recursion Vs Iteration៖
ពីការបង្រៀនពីមុនរបស់យើងនៅក្នុង Java យើងបានឃើញវិធីសាស្រ្តដដែលៗដែលយើងប្រកាសរង្វិលជុំ ហើយបន្ទាប់មកឆ្លងកាត់រចនាសម្ព័ន្ធទិន្នន័យក្នុងលក្ខណៈដដែលៗដោយយកធាតុមួយនៅ ពេលវេលាមួយ។
យើងក៏បានឃើញលំហូរតាមលក្ខខណ្ឌផងដែរ ដែលម្តងទៀតយើងរក្សាអថេររង្វិលជុំមួយ ហើយធ្វើកូដម្តងទៀតរហូតដល់អថេររង្វិលជុំត្រូវនឹងលក្ខខណ្ឌ។ នៅពេលនិយាយអំពីមុខងារហៅទូរសព្ទ យើងបានស្វែងយល់ពីវិធីសាស្រ្តដដែលៗសម្រាប់ការហៅតាមមុខងារផងដែរ។
នៅក្នុងមេរៀននេះ យើងនឹងពិភាក្សាអំពីវិធីសាស្រ្តផ្សេងគ្នាក្នុងការសរសេរកម្មវិធី ពោលគឺវិធីសាស្រ្ត Recursive។
តើ Recursion នៅក្នុង Java គឺជាអ្វី?
Recursion គឺជាដំណើរការមួយដែលមុខងារ ឬវិធីសាស្រ្តហៅខ្លួនឯងម្តងហើយម្តងទៀត។ មុខងារនេះដែលត្រូវបានហៅម្តងហើយម្តងទៀតដោយផ្ទាល់ ឬដោយប្រយោលត្រូវបានគេហៅថា "មុខងារកើតឡើងវិញ"។
យើងនឹងឃើញឧទាហរណ៍ជាច្រើនដើម្បីយល់ពីការហៅឡើងវិញ។ ឥឡូវយើងមើលវាក្យសម្ព័ន្ធនៃការធ្វើឡើងវិញ។
វាក្យសម្ព័ន្ធការបង្កើតឡើងវិញ
វិធីសាស្ត្រណាមួយដែលអនុវត្តការធ្វើឡើងវិញមានផ្នែកមូលដ្ឋានពីរ៖
- ការហៅតាមវិធីដែលអាចហៅខ្លួនឯងបាន ពោលគឺ recursive
- លក្ខខណ្ឌជាមុនដែលនឹងបញ្ឈប់ការហៅឡើងវិញ។
ចំណាំថាលក្ខខណ្ឌជាមុនគឺចាំបាច់សម្រាប់វិធីសាស្ត្រ recursive ដូចជាប្រសិនបើយើងមិនធ្វើ បំបែកrecursion បន្ទាប់មកវានឹងបន្តដំណើរការដោយគ្មានកំណត់ ហើយបណ្តាលឱ្យមានជង់លើស។
វាក្យសម្ព័ន្ធទូទៅនៃការបង្កើតឡើងវិញមានដូចខាងក្រោម៖
methodName (T parameters…) { if (precondition == true) //precondition or base condition { return result; } return methodName (T parameters…); //recursive call }
ចំណាំថាលក្ខខណ្ឌមុនត្រូវបានហៅផងដែរថា លក្ខខណ្ឌមូលដ្ឋាន។ យើងនឹងពិភាក្សាបន្ថែមអំពីលក្ខខណ្ឌមូលដ្ឋាននៅក្នុងផ្នែកបន្ទាប់។
ការយល់ដឹងអំពីការបង្កើតឡើងវិញនៅក្នុង Java
នៅក្នុងផ្នែកនេះ យើងនឹងព្យាយាមស្វែងយល់អំពីដំណើរការបង្កើតឡើងវិញ និងមើលថាតើវាកើតឡើងយ៉ាងដូចម្តេច។ យើងនឹងសិក្សាអំពីលក្ខខណ្ឌមូលដ្ឋាន ការហូរលើសជង់ និងមើលពីរបៀបដែលបញ្ហាជាក់លាក់មួយអាចត្រូវបានដោះស្រាយជាមួយនឹងការប្រើឡើងវិញ និងព័ត៌មានលម្អិតផ្សេងទៀត។
លក្ខខណ្ឌមូលដ្ឋាននៃការប្រើឡើងវិញ
ខណៈពេលកំពុងសរសេរកម្មវិធីដដែលៗ យើងគួរតែ ដំបូងផ្តល់ដំណោះស្រាយសម្រាប់ករណីមូលដ្ឋាន។ បន្ទាប់មកយើងបង្ហាញពីបញ្ហាធំជាងនេះទាក់ទងនឹងបញ្ហាតូចជាង។
ជាឧទាហរណ៍ យើងអាចយកបញ្ហាបុរាណនៃការគណនាហ្វាក់តូរីយ៉ែលនៃចំនួនមួយ។ ដោយផ្តល់លេខ n យើងត្រូវស្វែងរកហ្វាក់តូរីយ៉ែលនៃ n ដែលតំណាងដោយ n!
ឥឡូវនេះ ចូរយើងអនុវត្តកម្មវិធីដើម្បីគណនាលេខ ហ្វាក់តូរីយ៉ែល (n!) ដោយប្រើ recursion ។
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 ផ្នែកផ្សេងទៀតនៃមុខងារគឺការហៅឡើងវិញ។ ប៉ុន្តែរាល់ពេលដែលវិធីសាស្ត្រ recursive ត្រូវបានគេហៅថា n ត្រូវបានបន្ថយដោយ 1។
ដូច្នេះយើងអាចសន្និដ្ឋានថានៅទីបំផុតតម្លៃនៃ n នឹងក្លាយជា 1 ឬតិចជាង 1 ហើយនៅចំនុចនេះ។ចំណុច វិធីសាស្ត្រនឹងត្រឡប់តម្លៃ 1. លក្ខខណ្ឌមូលដ្ឋាននេះនឹងត្រូវបានឈានដល់ ហើយមុខងារនឹងឈប់។ ចំណាំថាតម្លៃនៃ n អាចជារបស់ណាមួយដរាបណាវាបំពេញលក្ខខណ្ឌមូលដ្ឋាន។
ការដោះស្រាយបញ្ហាដោយប្រើការហៅឡើងវិញ
គំនិតជាមូលដ្ឋានដែលនៅពីក្រោយការប្រើ recursion គឺដើម្បីបង្ហាញពីបញ្ហាធំជាងនៅក្នុងលក្ខខណ្ឌនៃ បញ្ហាតូចជាង។ ដូចគ្នានេះផងដែរ យើងត្រូវបន្ថែមលក្ខខណ្ឌមូលដ្ឋានមួយ ឬច្រើន ដើម្បីយើងអាចចេញពីការហៅឡើងវិញ។
វាត្រូវបានបង្ហាញរួចហើយនៅក្នុងឧទាហរណ៍ខាងដើមខាងលើ។ នៅក្នុងកម្មវិធីនេះ យើងបានបង្ហាញពី n factorial (n!) នៅក្នុងលក្ខខណ្ឌនៃតម្លៃតូចជាង និងមានលក្ខខណ្ឌមូលដ្ឋាន (n =1) ដូច្នេះនៅពេលដែល n ឈានដល់ 1 យើងអាចចាកចេញពីវិធីសាស្ត្រ recursive ។
Stack Overflow Error In Recursion
យើងដឹងហើយថានៅពេលដែល method ឬ function ណាមួយត្រូវបានហៅ ស្ថានភាពនៃ function ត្រូវបានរក្សាទុកនៅលើ stack ហើយត្រូវបានទាញយកមកវិញនៅពេលដែល function ត្រឡប់មកវិញ។ ជង់ត្រូវបានប្រើសម្រាប់វិធីសាស្ត្រ recursive ផងដែរ។
ប៉ុន្តែនៅក្នុងករណីនៃការកើតឡើងវិញ បញ្ហាអាចនឹងកើតឡើង ប្រសិនបើយើងមិនកំណត់លក្ខខណ្ឌមូលដ្ឋាន ឬនៅពេលដែលលក្ខខណ្ឌមូលដ្ឋានមិនត្រូវបានឈានដល់ ឬប្រតិបត្តិ។ ប្រសិនបើស្ថានភាពនេះកើតឡើង នោះការហូរលើសជង់អាចនឹងកើតឡើង។
សូមពិចារណាឧទាហរណ៍ខាងក្រោមនៃសញ្ញាហ្វាក់តូរីស។
នៅទីនេះ យើងបានផ្ដល់លក្ខខណ្ឌមូលដ្ឋានខុស 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
ក្នុងផ្នែកនេះ យើងនឹងអនុវត្តឧទាហរណ៍ខាងក្រោមដោយប្រើ recursion។
#1) ស៊េរី Fibonacci ដោយប្រើ Recursion
ស៊េរី Fibonacci ត្រូវបានផ្តល់ឱ្យដោយ,
1,1,2,3,5,8,13,21, 34,55,…
លំដាប់ខាងលើបង្ហាញថាធាតុបច្ចុប្បន្នគឺជាផលបូកនៃធាតុពីរមុន។ ផងដែរ ធាតុទីមួយនៅក្នុងស៊េរី Fibonacci គឺ 1.
ដូច្នេះជាទូទៅ ប្រសិនបើ n ជាចំនួនបច្ចុប្បន្ន នោះវាត្រូវបានផ្តល់ដោយផលបូកនៃ (n-1) និង (n-2)។ ដោយសារធាតុបច្ចុប្បន្នត្រូវបានបង្ហាញនៅក្នុងលក្ខខណ្ឌនៃធាតុមុន យើងអាចបង្ហាញពីបញ្ហានេះដោយប្រើការហៅឡើងវិញ។
កម្មវិធីដើម្បីអនុវត្តស៊េរី Fibonacci ត្រូវបានផ្តល់ឱ្យខាងក្រោម៖
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) + " "); } } }
Output
#2) ពិនិត្យមើលថាតើលេខមួយគឺជា Palindrome ដោយប្រើ Recursion
Palindrome គឺជាលំដាប់ដែលស្មើនៅពេលដែលយើង អានវាពីឆ្វេងទៅស្តាំ ឬពីស្តាំទៅឆ្វេង។
ដោយផ្តល់លេខ 121 យើងឃើញថានៅពេលដែលយើងអានពីឆ្វេងទៅស្តាំ និងស្តាំទៅឆ្វេង វាស្មើ។ ដូច្នេះលេខ 121 គឺជា palindrome ។
តោះយកលេខមួយទៀតគឺ 1242។ ពេលយើងអានពីឆ្វេងទៅស្តាំ វាគឺ 1242 ហើយពេលអានពីស្តាំទៅឆ្វេង វាអានថា 2421។ ដូច្នេះនេះមិនមែនជា palindrome ទេ។
យើងអនុវត្តកម្មវិធី palindrome ដោយបង្វែរខ្ទង់នៃលេខ ហើយប្រៀបធៀបលេខដែលបានផ្តល់ឱ្យឡើងវិញទៅតំណាងបញ្ច្រាសរបស់វា។
កម្មវិធីខាងក្រោមអនុវត្តកម្មវិធីដើម្បីពិនិត្យមើល palindrome ។
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 Output
#3) Reverse String Recursion Java
ដោយផ្តល់ខ្សែអក្សរ “Hello” យើងត្រូវបញ្ច្រាសវា ដូច្នេះ ខ្សែអក្សរលទ្ធផលគឺ "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); } }
Output
#4) Binary Search Java Recursion
ក្បួនដោះស្រាយការស្វែងរកប្រព័ន្ធគោលពីរគឺជាក្បួនដោះស្រាយដ៏ល្បីល្បាញសម្រាប់ការស្វែងរក។ នៅក្នុងក្បួនដោះស្រាយនេះ ដែលបានផ្តល់អារេតម្រៀបនៃធាតុ 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) ស្វែងរកតម្លៃអប្បបរមានៅក្នុង Array ដោយប្រើ Recursion
ដោយប្រើ recursion យើងក៏អាចស្វែងរកតម្លៃអប្បបរមានៅក្នុង Array ផងដែរ។
កម្មវិធី Java ដើម្បីស្វែងរកតម្លៃអប្បបរមានៅក្នុងអារេត្រូវបានផ្តល់ឱ្យខាងក្រោម។
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"); } }
លទ្ធផល
ទាំងនេះគឺជាមួយចំនួននៃ ឧទាហរណ៍នៃការកើតឡើងវិញ។ ក្រៅពីឧទាហរណ៍ទាំងនេះ បញ្ហាជាច្រើនផ្សេងទៀតនៅក្នុងកម្មវិធីអាចត្រូវបានអនុវត្តដោយប្រើបច្ចេកទេស recursive ។
ប្រភេទ Recursion
Recursion មានពីរប្រភេទដោយផ្អែកលើពេលដែលការហៅទូរសព្ទទៅ វិធីសាស្រ្ត recursive ។
ពួកវាគឺ៖
#1) Tail Recursion
នៅពេលដែលការហៅទៅកាន់វិធី recursive គឺជាសេចក្តីថ្លែងការណ៍ចុងក្រោយ ត្រូវបានប្រតិបត្តិនៅក្នុងវិធីសាស្ត្រ recursive វាត្រូវបានគេហៅថា "Tail Recursion"។
នៅក្នុង tail recursion, recursive call statement ជាធម្មតាត្រូវបានប្រតិបត្តិរួមជាមួយនឹង return statement នៃ method។
The វាក្យសម្ពន្ធទូទៅសម្រាប់ការហៅឡើងវិញកន្ទុយត្រូវបានផ្តល់ឱ្យខាងក្រោម៖
methodName ( T parameters…){ { if (base_condition == true) { return result; } return methodName (T parameters …) //tail recursion }
#2) Head Recursion
Head recursion គឺជាវិធីសាស្រ្ត recursive ណាមួយដែលមិនមែនជា tail recursion។ ដូច្នេះសូម្បីតែការហៅឡើងវិញទូទៅគឺការហៅឡើងវិញនៅខាងមុខ។
វាក្យសម្ព័ន្ធនៃការបង្កើតឡើងវិញក្បាលមានដូចខាងក្រោម៖
methodName (T parameters…){ if (some_condition == true) { return methodName (T parameters…); } return result; }
ការហៅឡើងវិញ Vs ការធ្វើឡើងវិញនៅក្នុង Java
Recursion | Iteration |
---|---|
Recursion គឺជាដំណើរការដែលវិធីសាស្រ្តហៅខ្លួនឯងម្តងហើយម្តងទៀតរហូតដល់លក្ខខណ្ឌមូលដ្ឋានត្រូវបានបំពេញ។ | ការបន្តគឺ ដំណើរការដែលបំណែកនៃកូដត្រូវបានប្រតិបត្តិម្តងហើយម្តងទៀតសម្រាប់ចំនួនដងកំណត់ ឬរហូតដល់លក្ខខណ្ឌត្រូវបានបំពេញ។ |
តើកម្មវិធីសម្រាប់មុខងារ។ | អាចអនុវត្តបាន សម្រាប់រង្វិលជុំ។ |
ដំណើរការល្អសម្រាប់ទំហំលេខកូដតូចជាង។ | ដំណើរការល្អសម្រាប់ទំហំកូដធំជាង។ |
ប្រើប្រាស់អង្គចងចាំកាន់តែច្រើន ដោយសារការហៅឡើងវិញនីមួយៗត្រូវបានរុញទៅជង់ | អង្គចងចាំតិចជាងប្រៀបធៀប ត្រូវបានប្រើ។ |
ពិបាកក្នុងការបំបាត់កំហុស និងថែទាំ | ងាយស្រួលបំបាត់កំហុស និងថែទាំ |
លទ្ធផលនៅក្នុងជង់លើសប្រសិនបើមូលដ្ឋាន លក្ខខណ្ឌមិនត្រូវបានបញ្ជាក់ ឬមិនឈានដល់។ | អាចប្រតិបត្តិដោយគ្មានកំណត់ ប៉ុន្តែទីបំផុតនឹងបញ្ឈប់ការប្រតិបត្តិដោយមានកំហុសអង្គចងចាំណាមួយ |
ភាពស្មុគស្មាញពេលវេលាគឺខ្ពស់ណាស់។ | ភាពស្មុគស្មាញនៃពេលវេលាគឺស្ថិតនៅផ្នែកខាងក្រោម។ |
សំណួរដែលគេសួរញឹកញាប់
សំណួរ #1) តើការ Recursion ដំណើរការយ៉ាងដូចម្តេចនៅក្នុង Java?
ចម្លើយ៖ នៅក្នុងការហៅឡើងវិញ មុខងារហៅខ្លួនឯងម្តងហើយម្តងទៀតរហូតដល់លក្ខខណ្ឌមូលដ្ឋានត្រូវបានពេញចិត្ត។ អង្គចងចាំសម្រាប់អនុគមន៍ដែលបានហៅត្រូវបានរុញទៅជង់នៅផ្នែកខាងលើនៃអង្គចងចាំសម្រាប់មុខងារហៅទូរសព្ទ។ សម្រាប់ការហៅតាមមុខងារនីមួយៗ ច្បាប់ចម្លងដាច់ដោយឡែកនៃអថេរមូលដ្ឋានត្រូវបានបង្កើតឡើង។
សំណួរ #2) ហេតុអ្វីត្រូវប្រើ Recursion?
ចម្លើយ៖ ការហៅឡើងវិញត្រូវបានប្រើដើម្បីដោះស្រាយបញ្ហាទាំងនោះ ដែលអាចបែងចែកទៅជាបញ្ហាតូចជាង ហើយបញ្ហាទាំងមូលអាចត្រូវបានបង្ហាញក្នុងន័យនៃបញ្ហាតូចជាង។
ការហៅឡើងវិញក៏ត្រូវបានប្រើសម្រាប់បញ្ហាទាំងនោះផងដែរ។ ស្មុគស្មាញដែលត្រូវដោះស្រាយដោយប្រើវិធីសាស្រ្តដដែលៗ។ ក្រៅពីបញ្ហាដែលភាពស្មុគស្មាញនៃពេលវេលាមិនមែនជាបញ្ហា សូមប្រើការហៅឡើងវិញ។
សំណួរ #3) តើអត្ថប្រយោជន៍នៃការហៅមកវិញ? នៃមុខងារ។
សំណួរ #4) តើមួយណាល្អជាង – Recursion ឬការនិយាយឡើងវិញ?
ចម្លើយ៖ ការហៅទូរសព្ទម្តងទៀត រហូតទាល់តែដល់មុខងារមូលដ្ឋាន។ ដូច្នេះមានអង្គចងចាំលើសដើម ដោយសារអង្គចងចាំសម្រាប់ការហៅមុខងារនីមួយៗត្រូវបានរុញទៅជង់។
ការរំលឹកឡើងវិញមិនមានអង្គចងចាំច្រើនលើសលប់ទេ។ ការប្រតិបត្តិឡើងវិញគឺយឺតជាងវិធីសាស្រ្តដដែលៗ។ Recursion កាត់បន្ថយទំហំនៃកូដ ខណៈពេលដែលវិធីសាស្រ្តដដែលៗធ្វើឱ្យកូដមានទំហំធំ។
សំណួរ #5) តើអត្ថប្រយោជន៍នៃការ Recursion ជាងការធ្វើឡើងវិញមានអ្វីខ្លះ?
ចម្លើយ៖
- Recursion ធ្វើឱ្យកូដកាន់តែច្បាស់ និងខ្លីជាង។
- Recursion គឺប្រសើរជាងវិធីសាស្រ្តដដែលៗសម្រាប់បញ្ហាដូចជា Tower of Hanoi, tree ដំណើរឆ្លងកាត់។ល។
- ដោយសាររាល់ការហៅមុខងារមានអង្គចងចាំត្រូវបានរុញទៅជង់ នោះ Recursion ប្រើអង្គចងចាំច្រើនជាង។
- ដំណើរការដំណើរការឡើងវិញគឺយឺតជាងវិធីសាស្ត្រដដែលៗ។
សេចក្តីសន្និដ្ឋាន
Recursion គឺជាគោលគំនិតដ៏សំខាន់មួយនៅក្នុងកម្មវិធី ដោយមិនគិតពីភាសាសរសេរកម្មវិធីឡើយ។ Recursion ភាគច្រើនត្រូវបានប្រើប្រាស់ក្នុងការដោះស្រាយបញ្ហារចនាសម្ព័ន្ធទិន្នន័យ ដូចជាប៉មនៃទីក្រុងហាណូយ ការឆ្លងកាត់ដើមឈើ បញ្ជីដែលបានភ្ជាប់។ល។ ទោះបីជាវាត្រូវការការចងចាំច្រើនក៏ដោយrecursion ធ្វើឱ្យកូដកាន់តែសាមញ្ញ និងច្បាស់ជាងមុន។
យើងបានស្វែងយល់អំពី Recursion ទាំងអស់នៅក្នុងមេរៀននេះ។ យើងក៏បានអនុវត្តឧទាហរណ៍កម្មវិធីជាច្រើនសម្រាប់ការយល់ដឹងកាន់តែច្បាស់អំពីគំនិត។