Maison développement back-end Tutoriel C#.Net Quelle est la complexité temporelle de l'algorithme récursif

Quelle est la complexité temporelle de l'algorithme récursif

Oct 24, 2019 am 10:53 AM
complexité temporelle 递归

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.

Quelle est la complexité temporelle de l'algorithme récursif

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 :

Quelle est la complexité temporelle de lalgorithme récursif

Un exemple peut être considéré avant d'introduire l'arbre récursif :

T(n) = 2T(n/2) + n2
Copier après la connexion

Itérer 2 fois pour obtenir :

T(n) = n2 + 2(2T(n/4) + (n/2) 2)
Copier après la connexion

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)
Copier après la connexion

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)
Copier après la connexion

Il s'agit d'une structure arborescente, à partir de laquelle la méthode de l'arbre récursif peut être dérivée.

Quelle est la complexité temporelle de lalgorithme récursif

(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
Copier après la connexion

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 :

Quelle est la complexité temporelle de lalgorithme récursif

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

Quelle est la complexité temporelle de lalgorithme récursif

, 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)
Copier après la connexion

1. d(n) est une constante :

 Quelle est la complexité temporelle de lalgorithme récursif

2 Lorsque d(n) = cn :

Quelle est la complexité temporelle de lalgorithme récursif

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

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)

Implémentation récursive des fonctions C++ : existe-t-il une limite à la profondeur de récursion ? Implémentation récursive des fonctions C++ : existe-t-il une limite à la profondeur de récursion ? Apr 23, 2024 am 09:30 AM

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 ;

Les expressions lambda C++ prennent-elles en charge la récursivité ? Les expressions lambda C++ prennent-elles en charge la récursivité ? Apr 17, 2024 pm 09:06 PM

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.

Implémentation récursive de fonctions C++ : Analyse comparative des algorithmes récursifs et non récursifs ? Implémentation récursive de fonctions C++ : Analyse comparative des algorithmes récursifs et non récursifs ? Apr 22, 2024 pm 03:18 PM

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.

Compter le nombre d'occurrences d'une sous-chaîne de manière récursive en Java Compter le nombre d'occurrences d'une sous-chaîne de manière récursive en Java Sep 17, 2023 pm 07:49 PM

É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.

Programme récursif pour trouver les éléments minimum et maximum d'un tableau en C++ Programme récursif pour trouver les éléments minimum et maximum d'un tableau en C++ Aug 31, 2023 pm 07:37 PM

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 ;

Comment analyser la complexité temporelle des fonctions récursives C++ ? Comment analyser la complexité temporelle des fonctions récursives C++ ? Apr 17, 2024 pm 03:09 PM

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).

Explication détaillée de la récursivité des fonctions C++ : application de la récursivité dans le traitement des chaînes Explication détaillée de la récursivité des fonctions C++ : application de la récursivité dans le traitement des chaînes Apr 30, 2024 am 10:30 AM

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.

Comment gérer les problèmes de complexité temporelle dans les fonctions PHP ? Comment gérer les problèmes de complexité temporelle dans les fonctions PHP ? Apr 26, 2024 pm 02:12 PM

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

See all articles