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

Prolog Discussion :

Liste de listes


Sujet :

Prolog

  1. #1
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut Liste de listes
    Bonjour,

    J'ai un petit problème dans un projet de Prolog. Voici ce qui me pose problème. Lorsque je rentre la règle suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    test(F,List):-not(member(F,List)),append(List,F,L),write(L).
    Le résultat L est une simple liste, alors que je voudrais une liste de listes sachant que l'appel se fait de la fonction suivante :
    ?- test([1,2,3,4,0,6,7,8,9],[1,2]).
    donne :
    [1, 2, 1, 2, 3, 4, 0, 6, 7, 8, 9]
    Yes
    Comment récupérer une liste de listes ?
    Merci
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  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
    Points : 6 498
    Points
    6 498
    Par défaut
    Je pense, d'après ce que tu dis, que déjà tu devrais faire,( si j'ai bien compris tu teste si une liste est une sous liste d'une autre liste)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    test([1,2], [[1,2,3,4,0,6,7,8,9]]).
    Et donc ensuite j'écrirais la règle sous cette forme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    test(A, B) :-
    	not(member(A, B)), append(B, [A], L), write(L).
    avec comme résultat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     test([1,2], [[1,2,3,4,0,6,7,8,9]]).
    [[1, 2, 3, 4, 0, 6, 7, 8, 9], [1, 2]]
    "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 habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut
    Merci beaucoup.
    J'en profite pour demander si pour un taquin (sous forme d'une liste de nombres), la solution de mémoriser les listes déjà effectuées afin de ne pas revenir sur ses pas est une bonne solution ?
    Etape suivante : chercher une heuristique qui permet de converger plus vite
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  4. #4
    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
    Points : 6 498
    Points
    6 498
    Par défaut
    oui, c'est une solution, celà dépend de la méthode de résolution que tu envisages.
    (style le mec qui se mouille pas trop )
    "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

  5. #5
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut
    Euh, encore un problème avec prolog. Lorsque j'ai des listes trop grandes, il ne m'affiche pas tout.

    Voici ce que ca donne :
    A = [h, d, b, b, g, h, h, d, b|...]
    Comment avoir toute la liste ?
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  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
    Points : 6 498
    Points
    6 498
    Par défaut
    Ben tu t'écris un write_list :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    write_liste([]) :- writeln(' ').
    write_liste([A|B]) :-
    	write(A), write(' '), write_liste(B).
    Pour en revenir à ta question précédente, pour les prog en prolog je fais comme ça (mémoriser les actions dans des listes et regarder si j'ai déjà fait), j'ai appris tout seul et je n'ai pas encore eu le temps de lire et comprendre en entier "L'Art de Prolog".

    J'ai fait un taquin en C, où j'ai travaillé différemment.
    "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

Discussions similaires

  1. [Lisp][IA] Supprimer une liste d'une liste de listes
    Par Superleo2999 dans le forum Lisp
    Réponses: 5
    Dernier message: 22/03/2010, 10h51
  2. Regrouper une liste en liste de listes
    Par West01 dans le forum Prolog
    Réponses: 12
    Dernier message: 14/03/2008, 14h07
  3. Liste de liste?
    Par Bethoring dans le forum C++
    Réponses: 4
    Dernier message: 16/11/2005, 18h19
  4. acceder au n iéme element d'une liste std::list
    Par sorari dans le forum SL & STL
    Réponses: 4
    Dernier message: 23/03/2005, 15h21
  5. [langage] tri avancé, liste de listes
    Par schnecke dans le forum Langage
    Réponses: 6
    Dernier message: 29/03/2004, 14h00

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