Skip to content

Commit

Permalink
FEATURE : Système de Marquages de Mines (#41)
Browse files Browse the repository at this point in the history
* FEAT: system mark with flags

* CHORE: update AUTHORS.md
  • Loading branch information
D-Davinson authored Nov 5, 2024
1 parent 7fb50a9 commit e68a62a
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 12 deletions.
1 change: 1 addition & 0 deletions AUTHORS.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,4 @@
- Alexandre ANTUNES MENDES, [email protected]
- Jimmy, Levacher, [email protected]
- Sebastien, LAFRIZI, [email protected]
- Davinson, DOGLAS PRINCE, [email protected]
46 changes: 34 additions & 12 deletions src/demineur.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ def __init__(self, fichier_sauvegarde='demineur.json', difficulte='moyen'):
"""
if difficulte not in ['facile', 'moyen', 'difficile']:
raise ValueError("Le niveau de difficulté doit être 'facile', 'moyen' ou 'difficile'.")

if difficulte == 'facile':
self.taille = 8
self.nombre_mines = 10
Expand All @@ -27,11 +26,11 @@ def __init__(self, fichier_sauvegarde='demineur.json', difficulte='moyen'):
else: # moyen
self.taille = 10
self.nombre_mines = 20

self.grille = [['.' for _ in range(self.taille)] for _ in range(self.taille)]
self.grille_visible = [['.' for _ in range(self.taille)] for _ in range(self.taille)]
self.statistiques = Statistiques()
self.fichier_sauvegarde = fichier_sauvegarde
self.marques = set()
self.__placer_mines()
self.__calculer_indices()

Expand All @@ -49,7 +48,6 @@ def __calculer_indices(self):
for x in range(self.taille):
if self.grille[y][x] == 'M':
continue

mines_autour = 0
for dx in range(y - 1, y + 2):
for dy in range(x - 1, x + 2):
Expand All @@ -58,16 +56,18 @@ def __calculer_indices(self):
continue
if self.grille[ny][nx] == 'M':
mines_autour += 1

self.grille[y][x] = str(mines_autour)

def decouvrir_cases(self, x, y):
"""A Function to uncover a cell"""
# Vérifier si les coordonnées sont dans les limites de la grille
if not (0 <= x < self.taille and 0 <= y < self.taille):
return
if self.grille_visible[y][x] == 'F':
self.grille_visible[y][x] = self.grille[y][x]
if self.grille_visible[y][x] != '.':
return

self.grille_visible[y][x] = self.grille[y][x]

if self.grille[y][x] == '0':
self.decouvrir_cases(x - 1, y)
self.decouvrir_cases(x + 1, y)
Expand Down Expand Up @@ -95,26 +95,49 @@ def charger_jeu(self):
'grille_visible',
[['.' for _ in range(self.taille)] for _ in range(self.taille)]
)
def marquer_case(self, x, y):
""" Mark or unmark a cell with a flag. """
if not (0 <= x < self.taille and 0 <= y < self.taille):
return
if self.grille_visible[y][x] == 'F':
self.grille_visible[y][x] = '.'
elif self.grille_visible[y][x] == '.':
self.grille_visible[y][x] = 'F'
else:
print("La case est déjà découverte et ne peut pas être marquée.")

def jouer(self):
"""A Function to launch the game"""

"""A Function to launch the game."""
game_in_progress = True
self.statistiques.start_timer()
while game_in_progress:
self.afficher_grille()
x, y = map(int, input("Entrez les coordonnees x et y separees par un espace: ").split())
try:
entree = input("'f x y' pour marquer/démarquer ou 'x y' pour découvrir : ").split()
if len(entree) == 3 and entree[0] == 'f':
# Mark/unmark the cells
x, y = map(int, entree[1:])
self.marquer_case(x, y)
continue
if len(entree) == 2:
# Discover the cells
x, y = map(int, entree)
else:
print("Error, entrer les coordonnées sous la forme 'x y' ou 'f x y'.")
continue
except ValueError:
print("Coordonnées invalides. Veuillez réessayer.")
continue
if self.grille[y][x] == 'M':
#Display the grid with the mine visible
self.decouvrir_cases(x, y)
self.decouvrir_cases(x,y)
self.afficher_grille()
print("Perdu !")
#End the game
game_in_progress = False
temps_ecoule = self.statistiques.stop_timer()
self.statistiques.record_loss()
break

self.decouvrir_cases(x, y)
if sum(row.count('.') for row in self.grille_visible) == self.nombre_mines:
print("Gagne !")
Expand All @@ -123,7 +146,6 @@ def jouer(self):
temps_ecoule = self.statistiques.stop_timer()
self.statistiques.record_victory()
break

print(f"Temps écoulé: {temps_ecoule:.2f} secondes")
self.statistiques.display_statistics()

Expand Down

0 comments on commit e68a62a

Please sign in to comment.