IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage Java Discussion :

Récursive, Itérative : quelle définition ?


Sujet :

Langage Java

  1. #1
    Membre expérimenté
    Avatar de yotta
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2006
    Messages
    1 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 088
    Points : 1 540
    Points
    1 540
    Par défaut Récursive, Itérative : quelle définition ?
    Bonjour à vous,

    Voilà, c'est très simple. Je suis autodidacte 100%, si bien que mon vocabulaire technique est plus personnel que standard. Et je n'arrive pas à comprendre ces deux termes lorsque je les rencontrent dans de nombreuses explications, ce qui a tendance à m'agacer.
    En fait, récursive je comprends, c'est itérative qui me dépasse.....

    Si l'un d'entre vous a deux minutes à perdre pour m'éclairer, j'en serai ravis.
    Une technologie n'est récalcitrante que par ce qu'on ne la connait et/ou comprend pas, rarement par ce qu'elle est mal faite.
    Et pour cesser de subir une technologie récalcitrante, n'hésitez surtout pas à visiter les Guides/Faq du site !

    Voici une liste non exhaustive des tutoriels qui me sont le plus familiers :
    Tout sur Java, du débutant au pro : https://java.developpez.com/cours/
    Tout sur les réseaux : https://reseau.developpez.com/cours/
    Tout sur les systèmes d'exploitation : https://systeme.developpez.com/cours/
    Tout sur le matériel : https://hardware.developpez.com/cours/

  2. #2
    Membre confirmé Avatar de Katachana
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Avril 2007
    Messages : 755
    Points : 503
    Points
    503
    Par défaut
    Les fonctions récursives sont des fonctions dont le calcul nécessite d'invoquer la fonction elle-même. la fonction s'appelle elle-meme.

    l'exemple classique est la suite de Fibonnacci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    long fib(unsigned long n) {
        if (n <= 1) {
            return n;
        } else {
            return fib(n-1)+fib(n-2);
        }
    }

    La fonction itérative, comme son nom l'indique, contient des itérations pour arriver au résultat final. (fonction avec des boucles par exemple for,foreach, while, etc..)

  3. #3
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    A titre d'exemple (et sauf erreur), l'algo iteratif pour la suite de fibonacci correspond à ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
        static long fib_i(long n) {
             long a = 0;
             long b = 1;
             long result = n;
     
             for (long i=2; i<=n; i++) {
                 result = a + b;
                 a = b;
                 b = result;
             }
             return result;
        }

    En règle général la version iterative d'un algo est plus performant que son équivalent recursive, car on évite d'empiler un grand nombre d'appel inutilement. La suite de Fibonacci en est un parfait exemple car avec la version recursif on arrive vite à saturation (temps de calcul de plus en plus long, et au bout d'un moment carrément une StackOverFlowException)


    a++

  4. #4
    Membre chevronné
    Inscrit en
    Août 2009
    Messages
    1 073
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 1 073
    Points : 1 806
    Points
    1 806
    Par défaut
    +1 sur les performances.

    Par contre, si le cas Fibonnaci est simple à gérer en itératif, il y a beaucoup de cas qui se codent très vite en récursif, et mais sont pénibles et peu intuitifs en itératif. Et donc ensuite, c'est un choix entre lisibilité et facilité vs performance.

  5. #5
    Membre expérimenté
    Avatar de yotta
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2006
    Messages
    1 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 088
    Points : 1 540
    Points
    1 540
    Par défaut Un grand merci à vous
    Merci Katachana, adiGuba et Rei Ichido.
    J'apprécie la précision de vos réponse. Malheureusement voyez-vous, je suis de plusieurs années lumières loin d'être un matheux...
    Mon niveau scolaire (qui est loin derrière moi aujourd'hui) c'est arrêté au Bac +2 en électrotechnique. Des suites, je sais en avoir étudié mais je n'ai plus aucun souvenir. Quelques transformé de Laplace, calculs différentiels, ça s'arrête là. Donc j'avoue avoir un peu paniqué en lisant fibonacci.... connais pas ?
    Bref, ça ne m'a pas empêché de comprendre vos explications. Mais là où je décroche, et j'avoue que personnellement, il ne me serait jamais arrivé de l'écrire comme ça mais à quelle occasion la forme décrite par Katachana représente-elle un intérrèt ?

    long fib(unsigned long n) {
    if (n <= 1) {
    return n;
    }
    else {
    return fib(n-1)+fib(n-2);
    }
    }
    Une technologie n'est récalcitrante que par ce qu'on ne la connait et/ou comprend pas, rarement par ce qu'elle est mal faite.
    Et pour cesser de subir une technologie récalcitrante, n'hésitez surtout pas à visiter les Guides/Faq du site !

    Voici une liste non exhaustive des tutoriels qui me sont le plus familiers :
    Tout sur Java, du débutant au pro : https://java.developpez.com/cours/
    Tout sur les réseaux : https://reseau.developpez.com/cours/
    Tout sur les systèmes d'exploitation : https://systeme.developpez.com/cours/
    Tout sur le matériel : https://hardware.developpez.com/cours/

  6. #6
    En attente de confirmation mail
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Octobre 2010
    Messages
    501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2010
    Messages : 501
    Points : 1 060
    Points
    1 060
    Par défaut
    Bonsoir,

    La suite de fibonaci est une suite numérique où chaque valeur est la somme des deux précédentes (en commençant par 0 et 1).
    Ca donne ça:
    f(0): 0
    f(1): 1
    f(2): 1
    f(3): 2
    f(4): 3
    f(5): 5
    f(6): 8
    f(7): 13
    f(8): 21
    ...

    La formule mathématique est donc f(n)=f(n-1)+f(n-2)
    C'est une formule récursive car l'exécution d'une fonction dépend d'une autre exécution de cette même fonction.

    Et pour répondre à la question: rédiger un algorithme de fibonaci de manière itérative est compliqué et probablement moche et incompréhensible alors que la forme récursive est tout à fait lisible et compréhensible quand on connaît la règle.

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    290
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 290
    Points : 426
    Points
    426
    Par défaut
    Citation Envoyé par pursang Voir le message
    Mais là où je décroche, et j'avoue que personnellement, il ne me serait jamais arrivé de l'écrire comme ça mais à quelle occasion la forme décrite par Katachana représente-elle un intérrèt ?
    Quand tu ne sais pas a priori combien de fois tu va faire ton traitement, comme pour une arborescence.

  8. #8
    Membre expérimenté
    Avatar de yotta
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Septembre 2006
    Messages
    1 088
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 088
    Points : 1 540
    Points
    1 540
    Par défaut OK
    Un grand merci à vous. Je crois qu'une ampoule vient de s'allumer dans mon cerveau...
    On apprend vraiment beaucoup de choses très intéressantes sur ce site. Bravo.
    Une technologie n'est récalcitrante que par ce qu'on ne la connait et/ou comprend pas, rarement par ce qu'elle est mal faite.
    Et pour cesser de subir une technologie récalcitrante, n'hésitez surtout pas à visiter les Guides/Faq du site !

    Voici une liste non exhaustive des tutoriels qui me sont le plus familiers :
    Tout sur Java, du débutant au pro : https://java.developpez.com/cours/
    Tout sur les réseaux : https://reseau.developpez.com/cours/
    Tout sur les systèmes d'exploitation : https://systeme.developpez.com/cours/
    Tout sur le matériel : https://hardware.developpez.com/cours/

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Quelle définition pour xml
    Par philippe6 dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 28/01/2014, 10h17
  2. Récursive -> itérative
    Par amlys dans le forum C
    Réponses: 1
    Dernier message: 03/03/2013, 10h05
  3. Liste itérative ou récursive
    Par devstud dans le forum C
    Réponses: 11
    Dernier message: 04/01/2007, 17h07
  4. Quelle CSS définition pour textbox asp.net ?
    Par mappy dans le forum Mise en page CSS
    Réponses: 3
    Dernier message: 29/07/2006, 18h18
  5. Quelles définitions pour la taille d'une base
    Par Christophe Charron dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 15/09/2005, 07h59

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo