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

Langage Perl Discussion :

Programmation autours d'un jeu [KHALOU]


Sujet :

Langage Perl

  1. #21
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Merci lolo pour ta vidéo des journées Perl sur le jeu : Bien utiliser les structures de données pour améliorer les performances

  2. #22
    Expert confirmé

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    3 577
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 577
    Points : 5 753
    Points
    5 753
    Par défaut
    Plus j'apprends, et plus je mesure mon ignorance (philou67430)
    Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book)
    Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé
    Si c'est utile, say

  3. #23
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 256
    Points
    12 256
    Billets dans le blog
    1
    Par défaut
    Merci à vous pour vos encouragements. Je pense qu'il y a maintenant prescription, je posterai le code de la solution au jeu de Khalou dès que j'ai le temps.


  4. #24
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Points : 12 256
    Points
    12 256
    Billets dans le blog
    1
    Par défaut
    Bonsoir,

    donc voilà, s'il s'agissait d'un devoir scolaire pour l'auteur du post de départ, l'échéance est forcément passée, je n'ai plus de scrupule à divulguer la solution complète. Et comme les moteurs de recherche peuvent amener des personnes intéressées sur ce fil, autant donner maintenant la solution complète que j'avais faite en février (d'autant plus que c'est l'un des trois exemples dont j'ai parlé publiquement aux Journées Perl 2013 à la mi-juin 2013, voir ci-dessus le lien donné par Djibril pour ceux que ça intéresse).

    Voici donc le code du programme:

    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
    use strict;
    use warnings;
     
    my @coup = qw /15 19 35 38 49 50 70 76 98 100 140 196 200 240 304 560 608 784 800 1120 1216 1568 1600 2240 3136 3200 3840 4369 4680 4864 8738 8960 9728 12544 12800 17476 17920 19456 25088 25600 33825 34952 35840 50176 51200 61440 /;
     
    my (%solutions, @count, $count, @sol_count);
    $solutions{0} = 0; 
    $count[0] = 1;
     
    foreach my $step (1..5) {
    	foreach my $sol1 (keys %solutions) {
    		next unless $solutions{$sol1} == ($step - 1);
    		foreach my $c (@coup) {
    			my $result = $sol1 ^ $c;
    			next if defined $solutions{$result};
    			$solutions{$result} = $step;
    			$count[$step]++;
    		}
    	}
    }
    print "il y a $count[$_] positions solubles en $_ coups. \n" for (0..5);
    Le code est d'une simplicité quasi biblique, et, en outre, j'ai expliqué à peu près tout dans les posts précédents, je ne vois rien à ajouter, mais me tiens à la disposition de quiconque désire des explications.

    Cette version du programme ne vise qu'à répondre à la question d'origine: combien de situations de départ solubles en 1, 2, 3, 4 et 5 coups.

    Moyennant deux ou trois toutes petites modifications, on peut stocker dans le hash le coup à exécuter pour chaque situation et créer, pour chaque situation de départ une sorte de liste chaînée des coups à exécuter successivement pour résoudre le problème de la meilleure façon possible.

    A noter aussi que dans ce cas précis, l'index du hash est finalement un nombre compris entre 0 et 65535. L'utilisation d'un tableau serait plus efficace (à la louche, à peu près deux fois plus rapide), mais, bon, quand on résout le problème en 2 ou 3 secondes, on s'en moque un peu. Dans ce cas précis, je veux juste ma solution en un temps acceptable, je n'ai aucun besoin de faire le mieux possible. Je suis donc resté avec un hash.

    Dernier point sur ce qui pourrait paraître être une incohérence dans mes propos: sur un post précédent, posté en février, j'ai parlé d'une durée d'exécution de moins de 3 secondes sur mon vieux portable. Aux Journées Perl de Nancy, je parle d'environ 1,5 seconde. La différence s'explique tout simplement par un changement d'ordinateur entre temps, et j'ai refait les mesures à zéro pour la préparation de ma présentation à Nancy.

Discussions similaires

  1. Programmation pattern missile pour jeu style shoot'em up
    Par mixka13 dans le forum XNA/Monogame
    Réponses: 7
    Dernier message: 19/05/2012, 14h36
  2. programmer une carte d’un jeu de stratégie
    Par swo.line dans le forum Développement 2D, 3D et Jeux
    Réponses: 4
    Dernier message: 10/01/2008, 22h20
  3. Réponses: 1
    Dernier message: 15/03/2007, 20h16
  4. Programmer autour du wifi.
    Par johnnyjohnny dans le forum Développement
    Réponses: 2
    Dernier message: 07/09/2006, 17h20
  5. Help ! Programmer un jeu vidéo
    Par Jay Bee dans le forum DirectX
    Réponses: 7
    Dernier message: 18/03/2004, 18h38

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