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 :

Prolog et les jeux


Sujet :

Prolog

  1. #21
    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
    As-tu une batterie de tests complète ?
    Pour le moment, les modifs que je fais permettent de valider les demandes mais si tu en rajoutes à chaque fois.
    Dernière mouture :
    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
    minsouliste([], []).
     
    minsouliste([H|T], MH1) :-
    	is_list(H), !,
    	minsouliste(H, MH),
    	minsouliste(T, MT),
    	(   is_list(MT) -> MH1 = [MH|MT]; MH1 = [MH |[MT]]).
     
    minsouliste([H|T], MH) :-
    	minsouliste1(T, H, MH).
     
     
    minsouliste1([H | T], MHC, [MHC | [ MH1 | MH2]]) :-
    	is_list(H), !,
    	minsouliste(H, MH1),
    	minsouliste(T, MH2).
     
     
    minsouliste1([H | T], MHC, MH) :-
    	H < MHC, !,
    	minsouliste1(T, H, MH).
     
    minsouliste1([_H | T], MHC, MH) :-
    	minsouliste1(T, MHC, MH).
     
    minsouliste1([], MH, MH).
     
     
    % la batteire de tests :
    test :-
    	minsouliste([[1,[2,5]]],R),
    	writeln(R),
    	writeln([[1,2]]),
    	minsouliste([2, [0, 1], [8, 2], 4], R1),
    	writeln(R1),
    	writeln([2,0,2,4]),
    	minsouliste([[[2,3,5],[3,0,2]],[2,3,9]],R3),
    	writeln(R3),
    	writeln([[2,0],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

  2. #22
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 9
    Points : 10
    Points
    10
    Par défaut
    non je n'ai pas une baterie de teste, mais même avc ce code ça donne tjrs le méméme résultat, le 4 il le rajoute bizarement à la fin de la liste:
    2 ?- minsouliste1([[[3,4],[6,7]],4],5,R).
    R = [5, [3, 6]|4].
    donc je comprend pas la!!

  3. #23
    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
    Pour t'aider à comprendre le problème :
    essaye en mode console
    L = [3 | 4].
    Puis
    Puis intéresse-toi à cette règle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    minsouliste1([H | T], MHC, [MHC | [ MH1 | MH2]]) :-
    	is_list(H), !,
    	minsouliste(H, MH1),
    	minsouliste(T, MH2).
    "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. #24
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 9
    Points : 10
    Points
    10
    Par défaut
    j'ai résolu le problème, mais je me suis rendu compte qu'il ne résoudera pas le problème du minimax, car dans le cas ou on aura:
    minsouliste([[5,3],[3,5],[3,[1,3]]],R).
    R = [3, 3, [3, 1]].
    on aura cessi alors qu on a besoin juste de [[5,3],[3,5],[3,1]]
    je ne sais pas si on pourra l'avoir ça?

Discussions similaires

  1. cherche sujet memoire en rapport avec les jeux videos
    Par elekis dans le forum Développement 2D, 3D et Jeux
    Réponses: 8
    Dernier message: 18/03/2006, 10h27
  2. [hardware][hdd] probleme de lag dans les jeux
    Par graphicsxp dans le forum Composants
    Réponses: 3
    Dernier message: 21/02/2006, 00h51
  3. Tutoriels sur les jeux de caractères
    Par tnntwister dans le forum Outils
    Réponses: 4
    Dernier message: 23/01/2006, 15h55
  4. [ETUDES] Après un DUT : aller vers les Jeux-Vidéo ?
    Par alex6891 dans le forum Etudes
    Réponses: 16
    Dernier message: 02/12/2005, 12h34
  5. Du réseau dans les jeux
    Par Mathieu.J dans le forum Développement
    Réponses: 3
    Dernier message: 07/05/2004, 16h33

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