Apprendre Maple Index du Forum Apprendre Maple
Site dédié au logiciel de calcul formel Maple
 
  Page d'accueilPage d'accueil   FAQFAQ    RechercherRechercher    Liste des MembresListe des Membres    Groupes d'utilisateursGroupes d'utilisateurs 
S'enregistrerS'enregistrer    ProfilProfil   Se connecter pour vérifier ses messages privésSe connecter pour vérifier ses messages privés   ConnexionConnexion 

Programme résolution puzzle

 
Poster un nouveau sujet   Répondre au sujet    Apprendre Maple Index du Forum -> Programmation
Voir le sujet précédent :: Voir le sujet suivant  
Auteur Message
tontonkilleur



Inscrit le: 25 Sep 2010
Messages: 1

MessagePosté le: 26 Sep 2010 15:47    Sujet du message: Programme résolution puzzle Répondre en citant

Bonjour ,
Je suis en train de travailler sur la création d'une procédure pour résoudre des puzzles coulissants(comme le taquin :http://fr.wikipedia.org/wiki/Taquin) . J'ai chercher sur le net pour trouver des informations sur le sujet mais le problème est que tous les algorithmes propose sur le net sont en C+ ou autre.
Pour le moment j'ai écrit sa :
> puzzle:=proc(M1,M2,n)
> local i,j,k,l,e:
> for i from 1 to n do
> for j from 1 to n do
> for k from 1 to n do
> for l from 1 to n do
> if M1[i,j]-M2[k,l]=0 then e[i,j]:=abs(i-k)+abs(j-l):fi:od:od:od:od:
> end:
M1 et M2 étant des matrices , M1 la position initiale du puzzle et M2 la position attendue .
Ex :
M1= matrix(3,3,[o,b,h,d,e,f,c,b,a]), M2:=matrix(3,3,[a,b,c,d,e,f,g,h,o]
e calcule "l'erreur" de chaque cases de la matrice , pour pouvoir bouger la case avec la plus grande erreur .
Mon problème est comment repérer la case vide (représenter par un o dans l'exemple) et savoir quels sont les cases adjacente a la case vide pour pouvoir ensuite les déplacer .
Merci
Revenir en haut de page
Voir le profil de l'utilisateur Envoyer un message privé
ALS



Inscrit le: 11 Sep 2006
Messages: 647

MessagePosté le: 27 Sep 2010 7:22    Sujet du message: Répondre en citant

Bonjour, déjà on peut commencer à récupérer les valeurs des erreurs dans une matrice e:

Code:

 puzzle:=proc(M1,M2,n)
>  local i,j,k,l,e:
>  e:=matrix(n,n):
>  for i from 1 to n do
>  for j from 1 to n do
>  for k from 1 to n do
>  for l from 1 to n do
>  if M1[i,j]-M2[k,l]=0 then e[i,j]:=abs(i-k)+abs(j-l):fi:od:od:od:od:
>  evalm(e):
> end:


> M1:= matrix(3,3,[o,b,h,d,e,f,c,b,a]); M2:=matrix(3,3,[a,b,c,d,e,f,g,h,o]);

 

                               [o    b    h]
                               [           ]
                         M1 := [d    e    f]
                               [           ]
                               [c    b    a]


                               [a    b    c]
                               [           ]
                         M2 := [d    e    f]
                               [           ]
                               [g    h    o]

> puzzle(M1,M2,3);

                            [4    0    3]
                            [           ]
                            [0    0    0]
                            [           ]
                            [4    2    4]


Ensuite vous écrivez une procédure pour récupérer les coordonnées correspondant à la plus grande erreur.

A plus tard.
Revenir en haut de page
Voir le profil de l'utilisateur Envoyer un message privé
Montrer les messages depuis:   
Poster un nouveau sujet   Répondre au sujet    Apprendre Maple Index du Forum -> Programmation Toutes les heures sont au format GMT + 2 Heures
Page 1 sur 1

 
Sauter vers:  
Vous ne pouvez pas poster de nouveaux sujets dans ce forum
Vous ne pouvez pas répondre aux sujets dans ce forum
Vous ne pouvez pas éditer vos messages dans ce forum
Vous ne pouvez pas supprimer vos messages dans ce forum
Vous ne pouvez pas voter dans les sondages de ce forum


phpBB

Développé par phpBB © 2001, 2006 phpBB Group
Traduction par : phpBB-fr.com


Apprendre Maple - ©  - Alain Le Stang - Navigation optimisée pour une résolution 1024 x 768.