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

Lisp Discussion :

[Lisp][Débutant] Récursivité incomplète


Sujet :

Lisp

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Décembre 2005
    Messages
    271
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 271
    Par défaut [Lisp][Débutant] Récursivité incomplète
    Bonjour,

    Voici mon code :
    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    (define (calcul p l lro )
      (cond ((null?( car l)) lro)
            (else calcul p (cdr l) (add p (car l) (cons(car (car l)) () ) (addr lro) lro) ) ) )
     
     
    (define (add p ltc lto lrc lro)
      (cond ((or (null? (cdr ltc)) 
                 (>  (+ (car (car ltc)) (car (car (cdr ltc)))) p))   
             (cond ((> (car (cdr (car ltc))) (car(cdr (car lrc)))) lto) 
                   (else lro )))  
     
            (else (add p 
                       (append (cons (cons (+ ( car (car ltc) ) (car (car (cdr ltc))))
                                           (cons (+ (car (cdr (car ltc))) (car (cdr (car (cdr ltc))))) ()) 
                                           )()) 
                               (cdr (cdr ltc)))
                       (append (cons (car (cdr ltc)) () ) lto) lrc lro))))
     
     
    ( define (addr ltc) 
       (cond ( (null? (cdr ltc) )  ltc)
             (else 
              (addr (
                     append (            
                             cons            
                             (                        
                              cons                                      
                              ( + ( car (car ltc) ) (car (car (cdr ltc) ) ) )                                              
                              (cons (+ (car (cdr (car ltc) ) ) ( car (cdr (car (cdr ltc) ) ) ) ) ())                                                     
                              )                                            
                             ()                                       
                             )                                       
                            (cdr (cdr ltc) )                                  
                            ) 
                    ) ) ) )
    J'envoie une liste l à "calcul" de type ( ( (2 3) (3 5) (3 5) ) ( (3 6) (6 2) (3 5) ) ), un argument p = 6, et un lro = car(car l)

    "Add" et "addr" font bien leur travail. Mais dès la premiere fois où le programme rentre dans addr, l'interpréteur me renvoie lro ou lto (suivant le cas) alors qu'elle doit normalement le renvoyer à la fonction calcul afin de continuer la récursivité. Comme d'habitude, je ne vois pas le problème...

    Merci

  2. #2
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    J'ai un peu tester et moi j'ai une erreur lorsque je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    (let* ((l '(((2 3) (3 5) (3 5)) ((3 6) (6 2) (3 5)) ))
           (lro (caar l)))
           (calcul 6 l lro))
    Tu pourrais donner exactement la fonction de lancement de calcul ?
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  3. #3
    Membre éclairé
    Inscrit en
    Décembre 2005
    Messages
    271
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 271
    Par défaut
    J ai modifié mon programme afin qu il soit plus lisible :
    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
     
    (define (sac-a-dos p l) 
      ( go p (constree l)  ) )
     
    (define (go p l)
      (calcul p l (list (car(car l)) ) )
     
    (define (calcul p l lro )
      (cond ((null?( car l)) lro)
            (else calcul p (cdr l) (add p (car l) (list (car (car l)) ) (addr lro) lro) ) ) )
     
    (define (add p ltc lto lrc lro) 
      (cond ((or (null? (cdr ltc)) ( > (+ (poids1 ltc) (poids2 ltc) ) p ) )   
             (cond ( (> (valeur1 ltc) (valeur1 lrc) ) lto) 
                   (else lro )))       
            (else (add p 
                       (append (list (cons (+ (poids1 ltc) (poids2 ltc) ) (list (+ (valeur1 ltc) (valeur2 ltc) ) ) ) )       
                               (cdr (cdr ltc) ) ) 
                       (append (list (car (cdr ltc)) ) lto) lrc lro))))
     
    ( define (addr ltc) 
       (cond ( (null? (cdr ltc) )  ltc)
             (else (addr (append (list (cons(+ (poids1 ltc) (poids2 ltc)) (list(+ (valeur1 ltc) ( valeur2 ltc) ) ) ) )                           
                                 (cdr (cdr ltc) ) ) ) ) ) ) 
     
    (define (constree l)
      (let* ((ll (reverse l))
             (tete (list(list (car ll))))
             (reste (cdr ll)))
        (let foo1 ((x reste) (y tete))
          (cond ((null? x) y)
                (else (foo1 (cdr x) 
                            (let foo2 ((xx (car x)) (yy y))
                              (cond ((null? yy) yy)
                                    (else (append (list (cons xx (car yy)) (car yy)) (foo2 xx (cdr yy))))))))))))
     
     
    (define (poids1 l )
      ( car(car l) ) )
     
    (define (poids2 l)
      ( car(car(cdr l) ) ) )  
     
    (define (valeur1 l) 
      ( car(cdr(car l) ) ) )
     
    (define (valeur2 l)
      ( car(cdr(car(cdr l) ) ) ) )
    Pour une liste de type '( (1 2)(3 4)(5 6) )
    poids1 = 1
    poids2 = 3
    valeur1 = 2
    valeur2 = 4

    Le tout se lance avec : (sac-a-dos '15 '( (1 2)(3 4)(15 6) )
    Les a list designent les objets et 15 le poids maximal
    Constree construit un arbre et l envoie a calcul (indirectement...)

    Calcul prends la tete de cette liste (donc une combinaison d'objets)
    Il les additonne entre eux jusqu a ce qu il depasse ou egale le poids max ou que la liste soit terminée
    Il compare ensuite la valeur de cette nouvelle combinaison et la valeur de la combinaison reponse (qui a la plus grande valeur a cet instant)

    Voila j ai teste ca hier, pas de probleme sauf cette recursivité incomplète

  4. #4
    Membre éclairé
    Inscrit en
    Décembre 2005
    Messages
    271
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 271
    Par défaut
    Pas de réponse ?

    est ce que le programme fonctionne chez vous ?

  5. #5
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    Salut

    je n'ai pas regardé tout le code mais j'ai un problème avec ce calcul
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (list (cons (+ (poids1 ltc) (poids2 ltc) ) (list (+ (valeur1 ltc) (valeur2 ltc)
    Tu additionnes les poids des objets ensemble et les nombre d'objets ensemble ?
    J'aurais cru qu'il fallait faire des multiplications entre les poids et le nombre d'objets de chaque liste ? C'est ça ou j'ai rien compris à ce que tu veux faire ?

    Ça me coince un peu avant de continuer.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  6. #6
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    Pour t'aider, j'ai besoin de savoir
    • ce que tu donnes en entrée
    • ce que tu espères obtenir en sortie
    C'est le meilleur moyen pour moi.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 13/02/2011, 13h51
  2. fonction Lisp [débutant]
    Par tangara001 dans le forum Lisp
    Réponses: 2
    Dernier message: 23/04/2010, 00h32
  3. [Débutante paumée] Récursivité
    Par germanika dans le forum Prolog
    Réponses: 3
    Dernier message: 02/03/2009, 23h29
  4. [débutant] choix distribution Lisp / Linux
    Par sg231 dans le forum Lisp
    Réponses: 1
    Dernier message: 20/08/2007, 20h16
  5. [Lisp][Débutant] Problème sur le principe
    Par Treuze dans le forum Lisp
    Réponses: 3
    Dernier message: 20/11/2006, 19h02

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