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 :

Pile sous GNU Prolog


Sujet :

Prolog

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 7
    Points
    7
    Par défaut Pile sous GNU Prolog
    Bonjour à tous,
    J'étais à la recherche d'une manière de modéliser les piles sous Prolog lorsque je suis tombé sur ce lien qui propose une solution sous SWI Prolog.

    Hors après plusieurs heures de recherche je n'arrive pas à l'adapter pour GNU Prolog, j'ai tenté ceci mais je n'arrive pas à retrouver la pile pour l'afficher une fois celle ci crée.

    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
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
     
    dynamic([p1/1, p2/1, p3/1]).
     
    % les prédicats de gestion de pile
    init_piles([]).
    init_piles([Pile | Q]) :-
    	P =.. [Pile, _X],
    	retractall(P),
    	P2 =.. [Pile, []],
    	asserta(P2),
    	init_piles(Q).
     
     
    pile_vide(Pile) :-
    	P =.. [Pile, []],
    	call(P).
     
    empile(Pile, Elem) :-
    	P =.. [Pile, X],
    	retract(P),
    	P1 =.. [Pile, [Elem | X]],
    	asserta(P1).
     
    depile(Pile, Elem) :-
    	P =.. [Pile, X],
    	retract(P),
    	X = [Elem | T],
    	P1 =.. [Pile, T],
    	asserta(P1).
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    empile_pile([], []).
    empile_pile([Pile | X], [Input | Y]) :-
    	empile(Pile, Input),
    	empile_pile(X, Y).
     
     
    test(Input) :-
    	% on calcule le nombre de sous listes
    	length(Input, N),
    	% on genere une liste du même nombre de piles
    	length(LP, N),
    	% on initialise les piles
    	init_piles([p1, p2, p3]),
    	% on les remplit avec les listes
    	empile_pile([p1, p2, p3], Input),
    	empile_pile([p1, p2, p3], [[x], [y], [z]]),
    	% on cree le tableau de sortie
    	%cree_tableau([], L),
    	% on l'ecrit à la console
    	afficher_liste_pile([p1, p2, p3]).
     
    % si les trois piles sont vides
    % Le tableau est termine
    /*cree_tableau(LP, L, L) :-
    	forall(member(P, LP), pile_vide(P)),
    	!.
     
    % on boucle sur la création du tableau
    cree_tableau(LP, L, LL) :-
    	maplist(extrait, LP, L1),
    	cree_tableau(LP, [L1 | L], LL).*/
     
    % on extrait un élément des piles
    % Si la pile est vide, on insère 0
    extrait(Pile, LL) :-
    	pile_vide(Pile) -> LL = 0;
    	depile(Pile, LL).
     
    afficher_liste_pile([]).
    afficher_liste_pile([T | Q]) :-
    	afficher_pile(T),
    	afficher_liste_pile(Q).
     
    afficher_pile(Pile) :-
    	P =.. [Pile, X],
    	write(X).
    En fait c'est uniquement lorsque je fais un retract que le compilateur reconnait le contenu de la pile (visible lorsqu'on debug). Du coup y aurait il une âme charitable pour adapter correctement le code ?

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 7
    Points
    7
    Par défaut
    Et il y a aussi le fait que je n'arrive pas à générer des chaînes uniques pour chaque pile pour ensuite appliquer les méthodes. Je sais que ça fait deux demandes mais je ne viendrais pas vous embeté si s'était très important pour moi, j'ai réellement besoin de trouver une solution à ce problème.

  3. #3
    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
    Une possibilité d'adaptation du code est de coder maplist sur GNU-Prolog, c'est un exo simple à faire (en plus en fouillant la doc SWI-Prolog...)
    "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. [GNU-Prolog][Mémoire] Local stack overflow
    Par Maxoo dans le forum Prolog
    Réponses: 15
    Dernier message: 04/06/2008, 22h15
  2. Programme Prolog sous Turbo Prolog
    Par killer_instinct dans le forum Prolog
    Réponses: 3
    Dernier message: 18/12/2006, 12h01
  3. Que veux dire _("chaine") sous gnu/linux?
    Par trois_1 dans le forum C
    Réponses: 3
    Dernier message: 25/08/2006, 14h12
  4. Sauvegarder les pages marqués sous GNU/Linux
    Par bnadem35 dans le forum Applications et environnements graphiques
    Réponses: 4
    Dernier message: 07/07/2006, 20h50
  5. Etat de la pile sous Linux et Windows
    Par Bibouda dans le forum x86 32-bits / 64-bits
    Réponses: 7
    Dernier message: 16/02/2003, 01h28

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