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 Delphi Discussion :

fonction multi récursive


Sujet :

Langage Delphi

  1. #1
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut fonction multi récursive
    Bonjour,

    comment arréter toutes les fonctions récursives qui portent le même nom?

    Je m'explique: j'ai une fonction qui s'appelle elle-même, mais à chaque execution, elle peut appeler plusieurs elles-mêmes avec des paramètres différents en même-temps. J'aimerais qu'arriver à une condition dans ma fonction, je puisse tout arréter et renvoyer quelque chose.

    j'arrive à renvoyer quelque chose mais une autre fonction continue pendant ce temps la...

    Je sais pas si j'ai été clair
    Merci
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  2. #2
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 725
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 725
    Points : 13 224
    Points
    13 224
    Par défaut
    Générer une exception.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Raise Exception.Create('Erreur');

  3. #3
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    oui mais cela ne vas arréter que la fonction qui l"a appelé mais celles qui ont été déclenché avant tourneront toujours..
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  4. #4
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 725
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 725
    Points : 13 224
    Points
    13 224
    Par défaut
    Raise déclenche un exception qui sera remontée jusqu'à un gestionnaire d'exception (try except) et à moins que tu passes par des threads, l'enchaînement de tes appels seront synchrones (l'un après l'autre). ça doit fonctionné

  5. #5
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    merci, j'essaierai et je confirme ou pas si ca marche.croisons les doigts..
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  6. #6
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    re

    dsl j'ai mis un peu de temps.

    Cela ne marche pas... Quand j'arrive à la premiere solution, il ne m'arrète pas la recherche des autres solutions (autrement dit des autres fonctions récursives toujours lancées)...

    Si quelqu'un à d'autres solutions...

    A moins que j'ai fait une erreur...
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  7. #7
    Membre émérite
    Homme Profil pro
    Directeur technique
    Inscrit en
    Mai 2008
    Messages
    2 401
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 2 401
    Points : 2 310
    Points
    2 310
    Par défaut
    Salut;

    La méthode classique; un booléen qui teste le résultat s'il est à faux on continue sinon un Exit.
    Bon courage ou Bonne Chance (selon le contexte)
    Mon blog sur WordPress

  8. #8
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 725
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 725
    Points : 13 224
    Points
    13 224
    Par défaut
    Comment savoir si tu as fait une erreur sans connaitre ton code .

    Tu as peut-être déjà un gestionnaire d'exception au niveau de ta procédure sans pour autant faire un re-Raise pour la remonter à la racine (le premier appel).

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    707
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 707
    Points : 777
    Points
    777
    Par défaut
    Ben oui, le classique marche toujours: une variable globale qu'on teste, ou une variable passée en paramètre.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function Test(var i: integer): integer;
    begin
      if i >= iMax then
        Exit;
     
      Result := Test(i + 1);
    end;

  10. #10
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    Je sais pas si je me suis bien expliqué. J'ai une fonction qui appelle plusieurs elles-mêmes du style:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    procedure truc(a)
    begin
    truc(a-1);
    truc(a+1);
    end;
    j'ai donc un arbre qui va se créer et pas seulement une chaine. Hors, à un moment donné, je vais tombé sur une solution, et il faut que j'arrète tout, toutes les precdure truc...
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  11. #11
    Membre éprouvé
    Avatar de Dr.Who
    Inscrit en
    Septembre 2009
    Messages
    980
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Septembre 2009
    Messages : 980
    Points : 1 294
    Points
    1 294
    Par défaut
    alors il faut faire une boucle plutot que d'utiliser la recursivité.

    1 - stopable par un seul Break/Exit
    2 - performant
    3 - pas d'erreur de stack overflow
    [ Sources et programmes de Dr.Who | FAQ Delphi | FAQ Pascal | Règlement | Contactez l'équipe ]
    Ma messagerie n'est pas la succursale du forum... merci!

  12. #12
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    heu je vois pas tro comment faire avcec des boucles... Je ne sais pas quelle taille fera mon arbre. Je cherche a trouver un chemin dans un arbre pour aller de A à B. J'avance et des que j'ai plusieurs choix pour poursuivre, je lances plusieurs procédures. En théorie, des que j'atteins une solution, si j'arrive à arréter tout et donner mon chemin, ce sera forcément le plus courtv et ce sans calcul tro fastidieu. Avec des boucles, c'est impossible tout ca.
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  13. #13
    Membre éprouvé
    Avatar de Dr.Who
    Inscrit en
    Septembre 2009
    Messages
    980
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Septembre 2009
    Messages : 980
    Points : 1 294
    Points
    1 294
    Par défaut
    [ame]http://fr.wikipedia.org/wiki/Arbre_binaire[/ame]

    la methode itérative infixe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    VisiterInfixeIteratif(racine)
        precedent    := null
        actuel       := racine
        suivant      := null
     
        Tant que (actuel != null) Faire
            Si (precedent == pere(actuel)) Alors
                precedent := actuel
                suivant   := gauche(actuel)
            FinSi
            Si (suivant == null OU precedent == gauche(actuel)) Alors
                Visiter(actuel)
                precedent := actuel
                suivant   := droite(actuel)
            FinSi
            Si (suivant == null OU precedent == droite(actuel)) Alors
                precedent := actuel
                suivant   := pere(actuel)
            FinSi
            actuel := suivant
        FinTantQue
    [ Sources et programmes de Dr.Who | FAQ Delphi | FAQ Pascal | Règlement | Contactez l'équipe ]
    Ma messagerie n'est pas la succursale du forum... merci!

  14. #14
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    Non non mais vous vous emballez.

    Une exception déclenchée avec raise et attrapée au plus haut niveau de la récursion avec un try..except fonctionnera très bien.
    Tu as dû te planter en écrivant ton gestionnaire.

    Peux-tu nous montrer ton code, avec surtout les parties où tu as mis le raise et le try..except ?
    sjrd, ancien rédacteur/modérateur Delphi.
    Auteur de Scala.js, le compilateur de Scala vers JavaScript, et directeur technique du Scala Center à l'EPFL.
    Découvrez Mes tutoriels.

  15. #15
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    dsl du temps mais j'ai revu entièrement le projet et je ne suis pas encore arriver à cette procédure mais je pense que je vais faire une version statique de cette fonction (que je voulais dynamique).

    C'est à dire que je vais utiliser des composants pour enregistrer mes différents chemins. Je vais laisser courir mes multiples fonctions récursives jusqu'à la fin (au lieu de tout arréter dés que j'ai une solution) et une fois fini, je compare les distances de tous les chemins trouvés et je renvoie le plus court... Pas trés optimisé, surtout si j'ai beaucoups de routes avec des noeuds communs.. Faudra que je voit à quelle vitesse ca tourne en pratique...
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

Discussions similaires

  1. [AC-2002] Fonction requête récursive VBA
    Par jobe3141 dans le forum Access
    Réponses: 11
    Dernier message: 24/02/2011, 16h30
  2. Fonctions multi types
    Par fanfouer dans le forum Débuter
    Réponses: 28
    Dernier message: 11/06/2010, 15h31
  3. [Turbo Pascal] Pile d'exécution pour la fonction factorielle récursive
    Par HASALGO dans le forum Turbo Pascal
    Réponses: 7
    Dernier message: 27/12/2009, 12h57
  4. Fonction multi utilisateur
    Par sondo dans le forum Administration
    Réponses: 1
    Dernier message: 01/04/2009, 10h01
  5. Exécution de fonctions multi fenetres
    Par djtadpole dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 31/05/2007, 18h33

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