


Quelle est la complexité temporelle de l'algorithme récursif
La complexité temporelle de l'algorithme récursif est : [T(n)=o(f(n))], ce qui signifie qu'à mesure que la taille du problème n augmente, le taux de croissance du temps d'exécution de l'algorithme et f (n) Le taux de croissance est proportionnel au taux de croissance, appelé complexité temporelle asymptotique de l'algorithme.
Complexité temporelle de l'algorithme récursif
Complexité temporelle :
Généralement, le nombre de répétitions des opérations de base dans l'algorithme est fonction f(n) de la taille du problème n, puis analysez le changement de f(n) avec n et déterminez l'ordre de grandeur de T(n). « o » est utilisé ici pour représenter l'ordre de grandeur et donne la complexité temporelle de l'algorithme.
T(n)=o(f(n));
Cela signifie qu'à mesure que la taille du problème n augmente, le taux de croissance du temps d'exécution de l'algorithme est proportionnel au taux de croissance de f(n) , appelée complexité temporelle asymptotique de l’algorithme. Et nous discutons généralement du pire des cas de complexité temporelle.
Cours recommandés : Tutoriel langage C
Complexité spatiale :
La complexité spatiale de l'algorithme n'est pas réellement un espace occupé , mais pour calculer le nombre d'unités spatiales auxiliaires dans tout l'espace algorithmique, ce qui n'a rien à voir avec l'ampleur du problème. La complexité spatiale S(n) d'un algorithme est définie comme l'ordre de grandeur de l'espace consommé par l'algorithme.
S(n)=o(f(n))
Si l'espace auxiliaire requis pour l'exécution de l'algorithme est une constante par rapport aux données d'entrée n, on l'appelle la complexité spatiale du algorithme L'espace auxiliaire est o(1);
La complexité spatiale de l'algorithme récursif : la profondeur de récursion n*l'espace auxiliaire requis pour chaque récursion. Si l'espace auxiliaire requis pour chaque récursion est une constante, le la complexité spatiale récursive est o (n).
L'équation de calcul de la complexité temporelle de l'algorithme récursif est une équation récursive :
Un exemple peut être considéré avant d'introduire l'arbre récursif :
T(n) = 2T(n/2) + n2
Itérer 2 fois pour obtenir :
T(n) = n2 + 2(2T(n/4) + (n/2) 2)
Vous pouvez également continuer à itérer et le développer complètement pour obtenir :
T(n) = n2 + 2((n/2) 2 + 2((n/22)2 + 2((n/23) 2 + 2((n/24) 2 +…+2((n/2i) 2 + 2T(n/2i + 1)))…))))……(1)
Et quand n/2i+ 1 == 1 , l'itération se termine.
Développez les parenthèses de l'équation (1), nous pouvons obtenir :
T(n) = n2 + 2(n/2)2 + 22(n/22) 2 + … + 2i(n/2i)2 + 2i+1T(n/2i+1)
Il s'agit d'une structure arborescente, à partir de laquelle la méthode de l'arbre récursif peut être dérivée.
(a)(b)(c)(d) sur la figure sont les étapes 1, 2, 3 et n respectivement dans la génération d'arbre récursive. Dans chaque nœud, l'élément libre actuel n2 est conservé, et les deux éléments récursifs T(n/2)
+ T(n/2) sont respectivement alloués à ses deux nœuds enfants, et ainsi de suite.
La somme de tous les nœuds du graphe est :
[1 + 1/2 + (1/2)2 + (1/2)3 + … + (1/2)i] n2 = 2n2
On peut voir que sa complexité temporelle est O(n2)
La règle de l'arbre récursif peut être obtenu comme :
(1) Le nœud de chaque couche est la valeur de f(n) dans T(n) = kT(n / m) + f(n) au actuel n/m;
(2) Le nombre de branches de chaque nœud est k
(3) Le côté droit de chaque couche marque la somme de tous les nœuds de la couche actuelle.
Autre exemple :
T(n) = T(n/3) + T(2n/3) + n
C'est le récursif L'arbre est comme indiqué ci-dessous :
On peut voir que la valeur de chaque couche est n, et le chemin le plus long de la racine au nœud feuille est :
Parce qu'à la fin La récursion s'arrête à (2/3)kn == 1. Puis
puis
, c'est-à-dire , T(n) = O(nlogn)
En résumé, utilisez cette méthode pour résoudre la complexité de l'algorithme récursif :
f(n) = af(n/b) + d(n)
1. d(n) est une constante :
2 Lorsque d(n) = cn :
3. L'arbre de récursion peut être utilisé lorsque d(n) est dans d'autres cas. Effectuer une analyse.
Dans le deuxième cas, si la méthode diviser pour régner est utilisée pour améliorer l'algorithme d'origine, l'accent est mis sur l'utilisation de nouvelles méthodes de calcul pour réduire la valeur de a.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

La profondeur de récursion des fonctions C++ est limitée et le dépassement de cette limite entraînera une erreur de débordement de pile. La valeur limite varie selon les systèmes et les compilateurs, mais se situe généralement entre 1 000 et 10 000. Les solutions incluent : 1. Optimisation de la récursion de queue ; 2. Appel de queue ; 3. Implémentation itérative ;

Oui, les expressions C++ Lambda peuvent prendre en charge la récursivité à l'aide de std::function : utilisez std::function pour capturer une référence à une expression Lambda. Avec une référence capturée, une expression Lambda peut s'appeler de manière récursive.

L'algorithme récursif résout des problèmes structurés grâce à l'auto-appel de fonctions. L'avantage est qu'il est simple et facile à comprendre, mais l'inconvénient est qu'il est moins efficace et peut provoquer un débordement de pile. L'algorithme non récursif évite la récursion en gérant explicitement le. structure de données de pile. L'avantage est qu'il est plus efficace et évite le débordement de pile, l'inconvénient est que le code peut être plus complexe. Le choix du récursif ou du non récursif dépend du problème et des contraintes spécifiques de la mise en œuvre.

Étant donné deux chaînes str_1 et str_2. Le but est de compter le nombre d'occurrences de la sous-chaîne str2 dans la chaîne str1 en utilisant une procédure récursive. Une fonction récursive est une fonction qui s'appelle dans sa définition. Si str1 est "Je sais que vous savez que je sais" et str2 est "savoir", le nombre d'occurrences est de -3 Comprenons à travers des exemples. Par exemple, entrez str1="TPisTPareTPamTP", str2="TP" ; sortie Countofoccurrencesofasubstringrecursi.

Nous prenons le tableau d'entiers Arr[] en entrée. Le but est de trouver les éléments les plus grands et les plus petits d’un tableau en utilisant une méthode récursive. Puisque nous utilisons la récursion, nous allons parcourir l'ensemble du tableau jusqu'à ce que nous atteignions length = 1, puis retourner A[0], qui constitue le cas de base. Sinon, l'élément actuel est comparé à la valeur minimale ou maximale actuelle et sa valeur est mise à jour de manière récursive pour les éléments suivants. Examinons différents scénarios d'entrée et de sortie pour cela −Input −Arr={12,67,99,76,32}; Output −Valeur maximale dans le tableau : 99 Explication &mi ;

L'analyse de la complexité temporelle des fonctions récursives implique : l'identification des cas de base et des appels récursifs. Calculez la complexité temporelle du cas de base et de chaque appel récursif. Additionnez la complexité temporelle de tous les appels récursifs. Considérez la relation entre le nombre d'appels de fonction et la taille du problème. Par exemple, la complexité temporelle de la fonction factorielle est O(n) car chaque appel récursif augmente la profondeur de récursion de 1, donnant une profondeur totale de O(n).

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 complexité temporelle est une mesure du temps nécessaire à l'exécution d'une fonction. Les problèmes courants de complexité temporelle des fonctions PHP incluent les boucles imbriquées, les parcours de grands tableaux et les appels récursifs. Les techniques d'optimisation de la complexité temporelle comprennent : l'utilisation de la mise en cache pour réduire le nombre de boucles la simplification des algorithmes à l'aide du traitement parallèle
