Une fonction récursive est une technique qui s'appelle à plusieurs reprises pour résoudre un problème de traitement de chaînes. Cela nécessite une condition de terminaison pour empêcher une récursion infinie. La récursivité est largement utilisée dans des opérations telles que l'inversion de chaînes et la vérification du palindrome.
La récursion est une technique dans laquelle une fonction s'appelle à plusieurs reprises pour résoudre un problème. Ceci est particulièrement utile dans le traitement de chaînes car les chaînes ont souvent une structure récursive.
Les fonctions récursives nécessitent une condition de terminaison pour empêcher une récursion infinie. Voici la forme générale d'une fonction récursive en C++ :
void f(参数); if (终止条件) { 函数体 } else { f(新参数); }
Exemple 1 : Inverser une chaîne
Étant donné une chaîne, écrivez une fonction récursive pour l'inverser.
#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" }
Exemple 2 : Vérification du palindrome
Étant donné une chaîne, écrivez une fonction récursive pour vérifier s'il s'agit d'un palindrome.
#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" }
La récursion est une technique puissante qui peut être utilisée pour résoudre divers problèmes de traitement de chaînes. Comprendre la syntaxe et les conditions de terminaison d'une fonction récursive est crucial pour l'utiliser efficacement. En utilisant judicieusement la récursivité, vous pouvez écrire du code concis et efficace pour gérer des chaînes complexes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!