Recursion in Java - ការបង្រៀនជាមួយឧទាហរណ៍

ការបង្រៀនស៊ីជម្រៅនេះ ស្តីពីការផ្សាយឡើងវិញនៅក្នុង Java ពន្យល់ពីអ្វីដែលជាការកើតឡើងវិញជាមួយនឹងឧទាហរណ៍ ប្រភេទ និងគំនិតដែលពាក់ព័ន្ធ។ វាក៏គ្របដណ្តប់លើ Recursion Vs Iteration៖

ពីការបង្រៀនពីមុនរបស់យើងនៅក្នុង Java យើងបានឃើញវិធីសាស្រ្តដដែលៗដែលយើងប្រកាសរង្វិលជុំ ហើយបន្ទាប់មកឆ្លងកាត់រចនាសម្ព័ន្ធទិន្នន័យក្នុងលក្ខណៈដដែលៗដោយយកធាតុមួយនៅ ពេលវេលាមួយ។

យើងក៏បានឃើញលំហូរតាមលក្ខខណ្ឌផងដែរ ដែលម្តងទៀតយើងរក្សាអថេររង្វិលជុំមួយ ហើយធ្វើកូដម្តងទៀតរហូតដល់អថេររង្វិលជុំត្រូវនឹងលក្ខខណ្ឌ។ នៅពេលនិយាយអំពីមុខងារហៅទូរសព្ទ យើងបានស្វែងយល់ពីវិធីសាស្រ្តដដែលៗសម្រាប់ការហៅតាមមុខងារផងដែរ។

នៅក្នុងមេរៀននេះ យើងនឹងពិភាក្សាអំពីវិធីសាស្រ្តផ្សេងគ្នាក្នុងការសរសេរកម្មវិធី ពោលគឺវិធីសាស្រ្ត Recursive។

តើ Recursion នៅក្នុង Java គឺជាអ្វី?

Recursion គឺជាដំណើរការមួយដែលមុខងារ ឬវិធីសាស្រ្តហៅខ្លួនឯងម្តងហើយម្តងទៀត។ មុខងារនេះដែលត្រូវបានហៅម្តងហើយម្តងទៀតដោយផ្ទាល់ ឬដោយប្រយោលត្រូវបានគេហៅថា "មុខងារកើតឡើងវិញ"។

យើងនឹងឃើញឧទាហរណ៍ជាច្រើនដើម្បីយល់ពីការហៅឡើងវិញ។ ឥឡូវ​យើង​មើល​វាក្យសម្ព័ន្ធ​នៃ​ការ​ធ្វើ​ឡើងវិញ។

វាក្យសម្ព័ន្ធ​ការ​បង្កើត​ឡើងវិញ

វិធីសាស្ត្រ​ណា​មួយ​ដែល​អនុវត្ត​ការ​ធ្វើ​ឡើងវិញ​មាន​ផ្នែក​មូលដ្ឋាន​ពីរ៖

  1. ការហៅតាមវិធីដែលអាចហៅខ្លួនឯងបាន ពោលគឺ recursive
  2. លក្ខខណ្ឌជាមុនដែលនឹងបញ្ឈប់ការហៅឡើងវិញ។

ចំណាំថាលក្ខខណ្ឌជាមុនគឺចាំបាច់សម្រាប់វិធីសាស្ត្រ 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) តើអត្ថប្រយោជន៍នៃការហៅមកវិញ? នៃមុខងារ។

  • Recursion អនុញ្ញាតឱ្យយើងដោះស្រាយបញ្ហាបានយ៉ាងងាយស្រួលបើប្រៀបធៀបទៅនឹងវិធីសាស្រ្តដដែលៗ។
  • សំណួរ #4) តើមួយណាល្អជាង – Recursion ឬការនិយាយឡើងវិញ?

    ចម្លើយ៖ ការហៅទូរសព្ទម្តងទៀត រហូតទាល់តែដល់មុខងារមូលដ្ឋាន។ ដូច្នេះមានអង្គចងចាំលើសដើម ដោយសារអង្គចងចាំសម្រាប់ការហៅមុខងារនីមួយៗត្រូវបានរុញទៅជង់។

    ការរំលឹកឡើងវិញមិនមានអង្គចងចាំច្រើនលើសលប់ទេ។ ការប្រតិបត្តិឡើងវិញគឺយឺតជាងវិធីសាស្រ្តដដែលៗ។ Recursion កាត់បន្ថយទំហំនៃកូដ ខណៈពេលដែលវិធីសាស្រ្តដដែលៗធ្វើឱ្យកូដមានទំហំធំ។

    សំណួរ #5) តើអត្ថប្រយោជន៍នៃការ Recursion ជាងការធ្វើឡើងវិញមានអ្វីខ្លះ?

    ចម្លើយ៖

    • Recursion ធ្វើឱ្យកូដកាន់តែច្បាស់ និងខ្លីជាង។
    • Recursion គឺប្រសើរជាងវិធីសាស្រ្តដដែលៗសម្រាប់បញ្ហាដូចជា Tower of Hanoi, tree ដំណើរឆ្លងកាត់។ល។
    • ដោយសាររាល់ការហៅមុខងារមានអង្គចងចាំត្រូវបានរុញទៅជង់ នោះ Recursion ប្រើអង្គចងចាំច្រើនជាង។
    • ដំណើរការដំណើរការឡើងវិញគឺយឺតជាងវិធីសាស្ត្រដដែលៗ។

    សេចក្តីសន្និដ្ឋាន

    Recursion គឺជាគោលគំនិតដ៏សំខាន់មួយនៅក្នុងកម្មវិធី ដោយមិនគិតពីភាសាសរសេរកម្មវិធីឡើយ។ Recursion ភាគច្រើនត្រូវបានប្រើប្រាស់ក្នុងការដោះស្រាយបញ្ហារចនាសម្ព័ន្ធទិន្នន័យ ដូចជាប៉មនៃទីក្រុងហាណូយ ការឆ្លងកាត់ដើមឈើ បញ្ជីដែលបានភ្ជាប់។ល។ ទោះបីជាវាត្រូវការការចងចាំច្រើនក៏ដោយrecursion ធ្វើឱ្យកូដកាន់តែសាមញ្ញ និងច្បាស់ជាងមុន។

    យើងបានស្វែងយល់អំពី Recursion ទាំងអស់នៅក្នុងមេរៀននេះ។ យើងក៏បានអនុវត្តឧទាហរណ៍កម្មវិធីជាច្រើនសម្រាប់ការយល់ដឹងកាន់តែច្បាស់អំពីគំនិត។

    អូសទៅកំពូល