Fungsi rekursif ialah teknik yang memanggil dirinya berulang kali untuk menyelesaikan masalah dalam pemprosesan rentetan. Ia memerlukan syarat penamatan untuk mengelakkan rekursi tak terhingga. Rekursi digunakan secara meluas dalam operasi seperti pembalikan rentetan dan pemeriksaan palindrom.
Rekursi ialah teknik di mana fungsi memanggil dirinya berulang kali untuk menyelesaikan masalah. Ia amat berguna dalam pemprosesan rentetan kerana rentetan selalunya mempunyai struktur rekursif.
Fungsi rekursif memerlukan syarat penamatan untuk mengelakkan rekursi tak terhingga. Berikut ialah bentuk umum fungsi rekursif dalam C++:
void f(参数); if (终止条件) { 函数体 } else { f(新参数); }
Contoh 1: Balikkan Rentetan
Diberi rentetan, tulis fungsi rekursif untuk membalikkannya.
#include <iostream> using namespace std; string reverse(string str) { if (str.empty()) { return ""; } else { return reverse(str.substr(1)) + str[0]; } } int main() { string s = "Hello World"; cout << reverse(s) << endl; // 输出 "dlroW olleH" }
Contoh 2: Menyemak Palindrom
Diberi rentetan, tulis fungsi rekursif untuk memeriksa sama ada ia adalah palindrom.
#include <iostream> using namespace std; bool isPalindrome(string str) { if (str.length() <= 1) { return true; } else { return str[0] == str[str.length() - 1] && isPalindrome(str.substr(1, str.length() - 2)); } } int main() { string s = "racecar"; cout << (isPalindrome(s) ? "Yes" : "No") << endl; // 输出 "Yes" }
Rekursi adalah teknik berkuasa yang boleh digunakan untuk menyelesaikan pelbagai masalah pemprosesan rentetan. Memahami sintaks dan syarat penamatan fungsi rekursif adalah penting untuk menggunakannya dengan berkesan. Dengan penggunaan rekursi yang bijak, anda boleh menulis kod yang ringkas dan cekap untuk mengendalikan rentetan yang kompleks.
Atas ialah kandungan terperinci Penjelasan terperinci tentang rekursi fungsi C++: aplikasi rekursi dalam pemprosesan rentetan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!