Apprendre Python dans le secondaire
Open Source Your Knowledge, Become a Contributor
Technology knowledge has to be shared and made accessible for free. Join the movement.
Inversion en croix
Difficulté : Extrême (100%)
Origine : Projet Euler n°331
NxN disques sont placés sur un grille carrée. Chaque disque a une face blanche et une face noire.
A chaque tour, on peut choisir un disque et tourner alors tous les disques de la même ligne et colonne : Il y a donc 2N-1 disques retournés. Le jeu fini quand tous les disques montrent la face blanche. Voici un exemple de jeu sur une grille 5x5.
On peut prouver que 3 est le nombre minimum de tours pour finir le jeu.
Le disque en bas à gauche de la grille a pour coordonnées (0,0), celui en bas à droite (N-1,0) et en haut à gauche (0,N-1).
On pose la configuration de la grille avec NxN disques suivante : Un disque de coordonnées (x,y) vérifiant
On pose
Trouver
On affichera le résultat avec print
.
Remarque : Si vous trouvez une solution qui met moins de 50 sec pour s'exécuter, je suis très intéressé !