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 :

[debutant] langages construits de manière inductive.


Sujet :

Prolog

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 22
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2020
    Messages : 3
    Points : 3
    Points
    3
    Par défaut [debutant] langages construits de manière inductive.
    Bonjour,

    alors voilà, j'aimerais construire sur prolog l'ensemble des palindromes sur {a,b}. Mais je rencontre quelques difficultés. Alors de base les mots a et b, représentés respectivement par les listes [a] et [b] appartiennent au langage. Ensuite, si un mot est un palindrome alors si on lui rajoute la même lettre au début et à la fin on obtient un nouveau palindrome. En me basant sur ça j'ai écris ces prédicats :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    langage6([a]).
    langage6([b]).
    langage6([a|Sp]):-langage6(S),addlast(a,S,Sp). (1)
    langage6([b|Sp]):-langage6(S),addlast(b,S,Sp). (2)
    avec addlast une fonction qui sert à ajouter un terme X à une liste L, le résultat est la liste Lp :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    addlast(X,[],[X]).
    addlast(X,[H|L],[H|Lp]):-addlast(X,L,Lp).
    J'ai plusieurs soucis avec ce code : lorsque je donne à l'interpréteur un mot qui n'est pas un palindrome il ne me retourne pas "false" mais il continue à chercher indéfiniment.
    Lorsque je lui demande la liste des palindromes il ne me donne que les mots qui commencent et se terminent par a. ("a,"b","a,a,a","a,b,a","a,a,a,a,a","a,a,b,a,a"). (à noter que si je change la place de 1 et 2 il ne me donne cette fois que les mots qui commence et se terminent par b).

  2. #2
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 22
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2020
    Messages : 3
    Points : 3
    Points
    3
    Par défaut Re
    Si vous pouviez me filer un coup de main pour parfaire le code ce serait avec plaisir !

  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
    Bonjour
    La question des palindrome en Prolog est classique.
    Beaucoup d'approches possibles, il suffit de taper Prolog palindrome sur votre moteur de recherche préféré !
    J'ai réécrit votre code langag6 en utilsant ce bon vieux append/3
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    langage6([]).
    langage6([_]).
    langage6(L) :-
        append([X|T], [X], L),
        langage6(T).
    PS Vous aviez une erreur dans la definition (testez langage6([a,a]).

    La génération des palindromes est assez difficile, essayez ceci, qui utilise les DCG :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    palindrome --> [].
    palindrome --> [a] | [b].
    palindrome --> [a], palindrome, [a].
    palindrome --> [b], palindrome, [b].
    et vous lancez la generation par :
    ?- phrase(palindrome, T).
    T = [] ;
    T = [a] ;
    T = [b] ;
    T = [a, a] ;
    T = [a, a, a] ;
    T = [a, b, a] ;
    T = [a, a, a, a] ;
    T = [a, a, a, a, a] ;
    T = [a, a, b, a, a] ;
    T = [a, a, a, a, a, a] ;
    ....
    Le "problème" de Prolog est que les clauses sont appliquées par Prolog dans l'ordre de leur apparition, d'où l'abondance des a ...
    "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

  4. #4
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2020
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 22
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2020
    Messages : 3
    Points : 3
    Points
    3
    Par défaut
    Bonjour,

    Merci pour vos précisions et d'avoir décelé mes erreurs. Je viens de tout corriger dans mon travail.

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

Discussions similaires

  1. [langage] Renseignement pour débuter sur perl
    Par freeshman dans le forum Langage
    Réponses: 2
    Dernier message: 29/04/2004, 23h47
  2. [langage] piti pb de débutant
    Par cottenceau dans le forum Langage
    Réponses: 4
    Dernier message: 29/04/2004, 13h23
  3. [langage] Ajout en debut de fichier
    Par WetzlarMan dans le forum Langage
    Réponses: 4
    Dernier message: 26/04/2004, 11h01
  4. [langage] [debutant]Entree standart
    Par toto_titi dans le forum Langage
    Réponses: 4
    Dernier message: 02/07/2003, 12h50
  5. [langage] [debutant] expression reguliere
    Par toto_titi dans le forum Langage
    Réponses: 3
    Dernier message: 01/07/2003, 09h45

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