Table des matières
1. La différence entre récursivité et itération
Dans le cas de base, il n'y aura aucun appel de fonction ici.
Maison Java javaDidacticiel Quelle est la différence entre la récursivité et l'itération en Java ?

Quelle est la différence entre la récursivité et l'itération en Java ?

May 02, 2023 pm 07:25 PM
java

1. La différence entre récursivité et itération

  • Lorsqu'une entité s'appelle, le programme est appelé récursif. 调用自身时,程序称为递归

  • 当存在循环(或重复)时,程序称为迭代调用

  • 示例:求一个数的阶乘的程序

 时间复杂度比较

  • 查找递归的时间复杂度比迭代更难。

  • 递归:递归的时间复杂度可以通过根据先前的调用找到第 n 次递归调用的值来找到。因此,根据基本情况找到目标情况,并根据基本情况求解,可以让我们了解递归方程的时间复杂度。

  • 迭代:迭代的时间复杂度可以通过找到循环内重复的循环数来找到。

 用法比较

  •  使用这些技术中的任何一种都是时间复杂度和代码大小之间的权衡。

  • 如果时间复杂度是重点,递归调用的次数会很大,那么最好使用迭代。

  • 但是,如果时间复杂度不是问题而代码的短小是问题,那么递归将是可行的方法。

  • 递归:递归涉及再次调用相同的函数,因此代码长度非常短。然而,正如我们在分析中看到的那样,当递归调用数量相当多时,递归的时间复杂度可能会呈指数级增长。因此,递归的使用在更短的代码中是有利的,但时间复杂度更高。

  • 迭代:迭代是代码块的重复。这涉及较大的代码量,但时间复杂度通常低于递归。

 开销

  • 与迭代相比,递归有大量的开销。

  • 递归:递归有函数重复调用的开销,即由于重复调用同一个函数代码的时间复杂度增加了很多倍

  • 迭代:迭代不涉及任何此类开销。

 无限重复

  •  递归中的 Infinite Repetition 会导致 CPU crash,但在迭代中,当内存耗尽时它会停止。

  • 递归:在Recursion中,由于指定的基本条件错误,可能会出现无限递归调用,在永远不会为假的情况下,不断调用函数,这可能会导致系统CPU崩溃。

  • 迭代

Lorsqu'il y a une boucle (ou répétition), le programme est appelé un appel itératif. Comparaison de la complexité temporelleTrouver la complexité temporelle de la récursivité est plus difficile que l'itération. Récursion : La complexité temporelle de la récursion peut être trouvée en trouvant la valeur du nième appel récursif en fonction des appels précédents. Par conséquent, trouver le cas cible sur la base du cas de base et le résoudre sur la base du cas de base nous permet de comprendre la complexité temporelle de l’équation récursive. Itération : La complexité temporelle de l'itération peut être trouvée en trouvant le nombre de boucles répétées dans la boucle. Comparaison d'utilisation L'utilisation de l'une de ces techniques est un compromis entre la complexité temporelle et la taille du code. Si la complexité temporelle est au centre de l'attention et que le nombre d'appels récursifs sera important, alors il est préférable d'utiliser l'itération. Cependant, si la complexité temporelle n'est pas un problème et que la brièveté du code l'est, alors la récursivité serait la voie à suivre. Récursion : La récursion implique d'appeler à nouveau la même fonction, la longueur du code est donc très courte. Cependant, comme nous l’avons vu dans notre analyse, la complexité temporelle de la récursivité peut croître de façon exponentielle lorsque le nombre d’appels récursifs est considérable. Par conséquent, l’utilisation de la récursivité est avantageuse dans un code plus court, mais avec une complexité temporelle plus élevée. Itération : L'itération est la répétition d'un bloc de code. Cela implique une plus grande quantité de code, mais la complexité temporelle est généralement inférieure à celle de la récursivité. Overhead Par rapport à l'itération, la récursivité a beaucoup de surcharge. Récursion : La récursion a la surcharge des appels de fonction répétés, c'est-à-dire, en raison des appels répétés à la même fonction, de la complexité temporelle du code augmente plusieurs fois code>. Itération : l'itération n'implique pas une telle surcharge. Répétition infinie La répétition infinie en récursion provoquera un crash du processeur, mais dans l'itération, elle s'arrêtera lorsque la mémoire sera épuisée. Récursion : En récursion, des appels récursifs infinis peuvent se produire en raison d'erreurs dans les conditions de base spécifiées. Les fonctions sont appelées en continu alors qu'elles ne sont jamais fausses, ce qui peut provoquer des pannes du processeur. Itération : une itération infinie due à une affectation d'itérateur ou à une erreur d'incrémentation ou à une mauvaise condition de terminaison entraînera une boucle infinie, qui peut ou non entraîner une erreur système, mais s'arrêtera définitivement la poursuite de l'exécution du programme. La fonction récursiveitérativedefine s'appelle elle-même. Un ensemble d'instructions exécutées à plusieurs reprises. Applicationspour la fonctionnalité. Pour les boucles. Termination
Exemple : Programme pour trouver la factorielle d'un nombre

Dans le cas de base, il n'y aura aucun appel de fonction ici.

🎜Lorsque la condition de terminaison de l’itérateur n’est plus remplie. 🎜🎜🎜🎜Utilisation🎜🎜À utiliser lorsque la taille du code doit être petite et que la complexité temporelle n'est pas un problème. 🎜🎜À utiliser lorsque la complexité temporelle doit être équilibrée par rapport à la taille du code étendue 🎜🎜🎜🎜Taille du code 🎜🎜Moins de code 🎜🎜Plus de code 🎜🎜🎜🎜Complexité temporelle 🎜🎜complexité temporelle très élevée (généralement exponentielle). 🎜🎜La complexité temporelle est relativement faible (généralement logarithme polynomial). 🎜🎜🎜🎜Complexité spatiale🎜🎜La complexité spatiale est supérieure à l'itération. 🎜🎜La complexité spatiale est faible. 🎜🎜🎜🎜Heap🎜🎜La pile ici est utilisée pour stocker les variables locales lorsque les fonctions sont appelées. 🎜🎜N'utilise pas de pile. 🎜🎜🎜🎜Vitesse🎜🎜L'exécution est lente car elle entraîne la maintenance et la mise à jour de la pile. 🎜🎜Généralement, c'est plus rapide que la récursivité car il n'utilise pas la pile. 🎜🎜🎜🎜Storage🎜🎜La récursion utilise plus de mémoire que l'itération. 🎜🎜Pas de surcharge puisqu'il n'y a pas d'appels de fonction dans l'itération. 🎜🎜🎜🎜Elevated🎜🎜a la surcharge des appels de fonction répétés. 🎜🎜Pas de surcharge puisqu'il n'y a pas d'appels de fonction dans l'itération. 🎜🎜🎜🎜Répétition infinie🎜🎜Si une fonction récursive ne satisfait pas à la condition de terminaison ou est indéfinie ou si le cas de base n'est jamais atteint, cela provoquera une erreur de débordement de pile et le système peut planter en récursion infinie. 🎜🎜Si la condition de contrôle de l'instruction d'itération n'est jamais fausse ou si la variable de contrôle n'atteint pas la valeur terminale, cela provoquera une boucle infinie. Dans une boucle infinie, il utilise encore et encore les cycles du processeur. 🎜🎜🎜🎜🎜2.

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Dead Rails - Comment apprivoiser les loups
4 Il y a quelques semaines By DDD
<🎜>: Grow A Garden - Guide de mutation complet
2 Il y a quelques semaines By DDD
Niveaux de force pour chaque ennemi et monstre de R.E.P.O.
4 Il y a quelques semaines 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)

Sujets chauds

Tutoriel Java
1659
14
Tutoriel PHP
1258
29
Tutoriel C#
1232
24
Break or Return of Java 8 Stream Forach? Break or Return of Java 8 Stream Forach? Feb 07, 2025 pm 12:09 PM

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

PHP: un langage clé pour le développement Web PHP: un langage clé pour le développement Web Apr 13, 2025 am 12:08 AM

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

PHP vs Python: comprendre les différences PHP vs Python: comprendre les différences Apr 11, 2025 am 12:15 AM

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

PHP vs autres langues: une comparaison PHP vs autres langues: une comparaison Apr 13, 2025 am 12:19 AM

PHP convient au développement Web, en particulier dans le développement rapide et le traitement du contenu dynamique, mais n'est pas bon dans les applications de la science des données et de l'entreprise. Par rapport à Python, PHP présente plus d'avantages dans le développement Web, mais n'est pas aussi bon que Python dans le domaine de la science des données; Par rapport à Java, PHP fonctionne moins bien dans les applications au niveau de l'entreprise, mais est plus flexible dans le développement Web; Par rapport à JavaScript, PHP est plus concis dans le développement back-end, mais n'est pas aussi bon que JavaScript dans le développement frontal.

PHP vs Python: fonctionnalités et fonctionnalités de base PHP vs Python: fonctionnalités et fonctionnalités de base Apr 13, 2025 am 12:16 AM

PHP et Python ont chacun leurs propres avantages et conviennent à différents scénarios. 1.PHP convient au développement Web et fournit des serveurs Web intégrés et des bibliothèques de fonctions riches. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et une bibliothèque standard puissante. Lors du choix, il doit être décidé en fonction des exigences du projet.

Programme Java pour trouver le volume de la capsule Programme Java pour trouver le volume de la capsule Feb 07, 2025 am 11:37 AM

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Impact de PHP: développement Web et au-delà Impact de PHP: développement Web et au-delà Apr 18, 2025 am 12:10 AM

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP: la fondation de nombreux sites Web PHP: la fondation de nombreux sites Web Apr 13, 2025 am 12:07 AM

Les raisons pour lesquelles PHP est la pile technologique préférée pour de nombreux sites Web incluent sa facilité d'utilisation, son soutien communautaire solide et son utilisation généralisée. 1) Facile à apprendre et à utiliser, adapté aux débutants. 2) Avoir une énorme communauté de développeurs et des ressources riches. 3) Largement utilisé dans WordPress, Drupal et d'autres plateformes. 4) Intégrez étroitement aux serveurs Web pour simplifier le déploiement du développement.

See all articles