Maison développement back-end C++ Implémentation récursive de fonctions C++ : Comment utiliser efficacement la récursion sur différentes structures de données ?

Implémentation récursive de fonctions C++ : Comment utiliser efficacement la récursion sur différentes structures de données ?

Apr 22, 2024 pm 12:06 PM
数据结构 递归 c++

La récursion gère efficacement les structures de données en C++, comme suit : Tableau : calcule facilement la valeur de la somme et trouve la valeur maximale Liste chaînée : calcule efficacement la longueur et la liste chaînée inversée Arbre : calcule rapidement la hauteur et le parcours de précommande

C++ 函数的递归实现:如何在不同的数据结构上有效使用递归?

Implémentation récursive C++ de Fonctions : appliquées efficacement aux structures de données

Introduction

La récursion est une technique de programmation puissante qui permet à une fonction de s'appeler elle-même. En C++, la récursivité peut être utilisée pour gérer diverses structures de données telles que des tableaux, des listes chaînées et des arbres. Cet article explorera comment la récursivité peut être appliquée à différentes structures de données et fournira quelques exemples pratiques sur la façon d'utiliser efficacement la récursivité.

Tableaux

  • Calcul de la somme des tableaux : En utilisant la récursivité, vous pouvez facilement calculer la somme des éléments du tableau :
int arraySum(int arr[], int n) {
  if (n <= 0) {
    return 0;
  }
  return arr[n-1] + arraySum(arr, n-1);
}
Copier après la connexion
  • Trouver la valeur maximale dans un tableau : La récursivité peut également être utilisée pour trouver la valeur maximale dans un tableau :
int findMax(int arr[], int n) {
  if (n == 1) {
    return arr[0];
  }
  int max = findMax(arr+1, n-1);
  return max > arr[0] ? max : arr[0];
}
Copier après la connexion

Liste chaînée

  • Trouver la longueur de la liste chaînée : La récursivité peut être utilisée pour calculer efficacement la longueur de la liste chaînée :
int linkedListLength(Node* head) {
  if (head == NULL) {
    return 0;
  }
  return linkedListLength(head->next) + 1;
}
Copier après la connexion
  • Inverse la liste chaînée : En utilisant la récursivité, vous pouvez également inverser facilement la liste chaînée :
Node* reverseLinkedList(Node* head) {
  if (head == NULL || head->next == NULL) {
    return head;
  }
  Node* next = head->next;
  head->next = NULL;
  Node* reversed = reverseLinkedList(next);
  next->next = head;
  return reversed;
}
Copier après la connexion

Arbre

  • Calculer la hauteur d'un arbre :La récursion est une manière courante de calculer la hauteur d'un arbre :
int treeHeight(Node* root) {
  if (root == NULL) {
    return 0;
  }
  int leftHeight = treeHeight(root->left);
  int rightHeight = treeHeight(root->right);
  return max(leftHeight, rightHeight) + 1;
}
Copier après la connexion
  • Parcours en précommande :La récursion peut être utilisée pour parcourir un arbre en précommande :
void preorderTraversal(Node* root) {
  if (root == NULL) {
    return;
  }
  cout << root->data << " ";
  preorderTraversal(root->left);
  preorderTraversal(root->right);
}
Copier après la connexion

Conclusion

La récursion est un outil puissant qui fournit un moyen élégant de gérer efficacement différentes structures de données. Améliorez vos compétences en codage C++ en comprenant les principes de récursivité et en appliquant les exemples pratiques fournis dans cet article.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Conception sécurisée de structures de données en programmation simultanée C++ ? Conception sécurisée de structures de données en programmation simultanée C++ ? Jun 05, 2024 am 11:00 AM

Conception sécurisée de structures de données en programmation simultanée C++ ?

La disposition des objets C++ est alignée sur la mémoire pour optimiser l'efficacité de l'utilisation de la mémoire La disposition des objets C++ est alignée sur la mémoire pour optimiser l'efficacité de l'utilisation de la mémoire Jun 05, 2024 pm 01:02 PM

La disposition des objets C++ est alignée sur la mémoire pour optimiser l'efficacité de l'utilisation de la mémoire

Comment implémenter un comparateur personnalisé en C++ STL ? Comment implémenter un comparateur personnalisé en C++ STL ? Jun 05, 2024 am 11:50 AM

Comment implémenter un comparateur personnalisé en C++ STL ?

Comment implémenter le Strategy Design Pattern en C++ ? Comment implémenter le Strategy Design Pattern en C++ ? Jun 06, 2024 pm 04:16 PM

Comment implémenter le Strategy Design Pattern en C++ ?

Similitudes et différences entre Golang et C++ Similitudes et différences entre Golang et C++ Jun 05, 2024 pm 06:12 PM

Similitudes et différences entre Golang et C++

Comment copier un conteneur STL C++ ? Comment copier un conteneur STL C++ ? Jun 05, 2024 am 11:51 AM

Comment copier un conteneur STL C++ ?

Quels sont les principes d'implémentation sous-jacents des pointeurs intelligents C++ ? Quels sont les principes d'implémentation sous-jacents des pointeurs intelligents C++ ? Jun 05, 2024 pm 01:17 PM

Quels sont les principes d'implémentation sous-jacents des pointeurs intelligents C++ ?

Comment implémenter une programmation multithread C++ basée sur le modèle Actor ? Comment implémenter une programmation multithread C++ basée sur le modèle Actor ? Jun 05, 2024 am 11:49 AM

Comment implémenter une programmation multithread C++ basée sur le modèle Actor ?

See all articles