Methodes en trop supprimée + nettoyage git

This commit is contained in:
Vincent TEISSIER 2024-05-04 14:59:38 +02:00
parent 8adb8b4547
commit 12ae377ec0
5 changed files with 81 additions and 121 deletions

@ -3,22 +3,22 @@ import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
public class Grid { public class Grid {
private Cell[][] cells; private Cell[][] cell;
public Grid() { public Grid() {
cells = new Cell[9][9]; cell = new Cell[9][9];
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) { for (int j = 0; j < 9; j++) {
cells[i][j] = new Cell(); cell[i][j] = new Cell();
} }
} }
} }
public Grid(Grid grid) { public Grid(Grid grid) {
cells = new Cell[9][9]; cell = new Cell[9][9];
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) { for (int j = 0; j < 9; j++) {
cells[i][j] = new Cell(grid.cells[i][j].getValue()); cell[i][j] = new Cell(grid.cell[i][j].getValue());
} }
} }
} }
@ -32,9 +32,9 @@ public class Grid {
line = "000000000".substring(length) + line; // Ajoute les zéros au début si nécessaire line = "000000000".substring(length) + line; // Ajoute les zéros au début si nécessaire
} }
for (int column = 0; column < 9; column++) { for (int column = 0; column < 9; column++) {
char digit = line.charAt(column); char number = line.charAt(column);
int value = Character.getNumericValue(digit); int value = Character.getNumericValue(number);
cells[ligne][column].setValue(value); cell[ligne][column].setValue(value);
} }
} }
System.out.println("Success"); System.out.println("Success");
@ -45,13 +45,13 @@ public class Grid {
} }
public Cell getCell(int ligne, int col) { public Cell getCell(int ligne, int col) {
return cells[ligne][col]; return cell[ligne][col];
} }
public void copyFrom(Grid other) { public void copyFrom(Grid second_grid) {
for (int row = 0; row < 9; row++) { for (int row = 0; row < 9; row++) {
for (int col = 0; col < 9; col++) { for (int col = 0; col < 9; col++) {
this.cells[row][col].setValue(other.cells[row][col].getValue()); this.cell[row][col].setValue(second_grid.cell[row][col].getValue());
} }
} }
} }
@ -59,7 +59,7 @@ public class Grid {
public void printGrid() { public void printGrid() {
for (int row = 0; row < 9; row++) { for (int row = 0; row < 9; row++) {
for (int col = 0; col < 9; col++) { for (int col = 0; col < 9; col++) {
System.out.print(cells[row][col].getValue() + " "); System.out.print(cell[row][col].getValue() + " ");
} }
System.out.println(); System.out.println();
} }

@ -6,9 +6,13 @@ public class Sudoku {
this.grid = new Grid(); // Initialiser avec une grille vide this.grid = new Grid(); // Initialiser avec une grille vide
this.solved = false; this.solved = false;
} }
public static void main(String[] args) {
Sudoku sudoku = new Sudoku();
sudoku.printGrid(); // Afficher la grille non résolue dans la console
new SudokuUI(sudoku);
}
public Grid getGrid() { public Grid getGrid() {
return grid; return grid;
} }
@ -20,14 +24,10 @@ public class Sudoku {
public boolean isSolved() { public boolean isSolved() {
return solved; return solved;
} }
public static void main(String[] args) { public void loadGridFromFile(String fileName) {
Sudoku sudoku = new Sudoku(); this.grid.loadGridFromFile(fileName);
sudoku.printGrid(); // Afficher la grille non résolue dans la console
new SudokuUI(sudoku);
} }
public void printGrid() { public void printGrid() {
for (int row = 0; row < 9; row++) { for (int row = 0; row < 9; row++) {
@ -39,82 +39,4 @@ public class Sudoku {
} }
} }
public boolean generateSudoku() {
for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) {
if (!solveSudoku(i, j)) {
return false;
}
}
}
return true;
}
private boolean solveSudoku(int row, int col) {
if (row == 9 - 1 && col == 9) {
return true;
}
if (col == 9) {
row++;
col = 0;
}
if (grid.getCell(row, col).getValue() != 0) {
return solveSudoku(row, col + 1);
}
for (int num = 1; num <= 9; num++) {
if (isSafe(row, col, num)) {
grid.getCell(row, col).setValue(num);
if (solveSudoku(row, col + 1)) {
return true;
}
}
grid.getCell(row, col).setValue(0);
}
return false;
}
private boolean isSafe(int row, int col, int num) {
// Vérifiez si nous trouvons le même numéro dans la même ligne,
// la même colonne ou la même sous-grille
return !findInRow(row, num) && !findInCol(col, num) && !findInBox(row - row % 3, col - col % 3, num);
}
// Méthodes findInRow, findInCol et findInBox ici
private boolean findInRow(int row, int num) {
for (int col = 0; col < 9; col++) {
if (grid.getCell(row, col).getValue() == num) {
return true;
}
}
return false;
}
private boolean findInCol(int col, int num) {
for (int row = 0; row < 9; row++) {
if (grid.getCell(row, col).getValue() == num) {
return true;
}
}
return false;
}
private boolean findInBox(int boxStartRow, int boxStartCol, int num) {
for (int row = 0; row < 3; row++) {
for (int col = 0; col < 3; col++) {
if (grid.getCell(row + boxStartRow, col + boxStartCol).getValue() == num) {
return true;
}
}
}
return false;
}
public void loadGridFromFile(String fileName) {
this.grid.loadGridFromFile(fileName);
}
} }

@ -4,16 +4,16 @@ import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
public class SudokuButtonListener implements ActionListener { public class SudokuButtonListener implements ActionListener {
private int ligne; private int row;
private int col; private int col;
private Sudoku sudoku; private Sudoku sudoku;
private JButton[][] boutons; private JButton[][] buttons;
public SudokuButtonListener(int ligne, int col, Sudoku sudoku, JButton[][] boutons) { public SudokuButtonListener(int row, int col, Sudoku sudoku, JButton[][] buttons) {
this.ligne = ligne; this.row = row;
this.col = col; this.col = col;
this.sudoku = sudoku; this.sudoku = sudoku;
this.boutons = boutons; this.buttons = buttons;
} }
@Override @Override
@ -22,16 +22,16 @@ public class SudokuButtonListener implements ActionListener {
if (input != null && input.length() > 0) { if (input != null && input.length() > 0) {
try { try {
int num = Integer.parseInt(input); int num = Integer.parseInt(input);
sudoku.getGrid().getCell(ligne, col).setValue(num); sudoku.getGrid().getCell(row, col).setValue(num);
if (num == 0) { if (num == 0) {
boutons[ligne][col].setText(""); // Case vide si le nombre est 0 buttons[row][col].setText(""); // Case vide si le nombre est 0
} else { } else {
boutons[ligne][col].setText(String.valueOf(num)); buttons[row][col].setText(String.valueOf(num));
} }
if (!isValidMove(num, ligne, col)) { if (!isValid(num, row, col)) {
boutons[ligne][col].setForeground(Color.RED); // Met le texte en rouge en cas de mouvement invalide buttons[row][col].setForeground(Color.RED); // Met le texte en rouge en cas de mouvement invalide
} else { } else {
boutons[ligne][col].setForeground(Color.BLACK); // Réinitialise la couleur du texte buttons[row][col].setForeground(Color.BLACK); // Réinitialise la couleur du texte
} }
} catch (NumberFormatException ex) { } catch (NumberFormatException ex) {
JOptionPane.showMessageDialog(null, "Veuillez entrer un nombre valide."); JOptionPane.showMessageDialog(null, "Veuillez entrer un nombre valide.");
@ -39,13 +39,13 @@ public class SudokuButtonListener implements ActionListener {
} }
} }
private boolean isValidMove(int num, int ligne, int col) { private boolean isValid(int num, int row, int col) {
return isValidRow(num, ligne) && isValidCol(num, col) && isValidBox(num, ligne - ligne % 3, col - col % 3); return isValidRow(num, row) && isValidCol(num, col) && isValidBox(num, row - row % 3, col - col % 3);
} }
private boolean isValidRow(int num, int ligne) { private boolean isValidRow(int num, int row) {
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
if (sudoku.getGrid().getCell(ligne, i).getValue() == num && i != col) { if (sudoku.getGrid().getCell(row, i).getValue() == num && i != col) {
return false; return false;
} }
} }
@ -54,19 +54,19 @@ public class SudokuButtonListener implements ActionListener {
private boolean isValidCol(int num, int col) { private boolean isValidCol(int num, int col) {
for (int i = 0; i < 9; i++) { for (int i = 0; i < 9; i++) {
if (sudoku.getGrid().getCell(i, col).getValue() == num && i != ligne) { if (sudoku.getGrid().getCell(i, col).getValue() == num && i != row) {
return false; return false;
} }
} }
return true; return true;
} }
private boolean isValidBox(int num, int Row, int Col) { private boolean isValidBox(int num, int boxStartRow, int boxStartCol) {
for (int i = 0; i < 3; i++) { for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) { for (int j = 0; j < 3; j++) {
int ligne = i + Row; int row = i + boxStartRow;
int col = j + Col; int col = j + boxStartCol;
if (sudoku.getGrid().getCell(ligne, col).getValue() == num && (ligne != this.ligne || col != this.col)) { if (sudoku.getGrid().getCell(row, col).getValue() == num && (row != this.row || col != this.col)) {
return false; return false;
} }
} }

@ -1,6 +1,19 @@
public class SudokuSolver { public class SudokuSolver {
public boolean solve(Grid grid) { public boolean solve(Grid grid) {
return solveRecursive(grid); long startTime = System.currentTimeMillis(); // Temps de début de la résolution
boolean isSolved = solveRecursive(grid);
long endTime = System.currentTimeMillis(); // Temps de fin de la résolution
long duration = endTime - startTime; // Calcul de la durée de résolution
if (isSolved) {
System.out.println("La grille a été résolue en " + duration + " millisecondes.");
} else {
System.out.println("La grille est insoluble.");
}
return isSolved;
} }
private boolean solveRecursive(Grid grid) { private boolean solveRecursive(Grid grid) {

@ -2,6 +2,8 @@ import javax.swing.*;
import java.awt.*; import java.awt.*;
import java.awt.event.ActionEvent; import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
import java.io.File;
import javax.swing.filechooser.FileNameExtensionFilter;
public class SudokuUI extends JFrame { public class SudokuUI extends JFrame {
private Sudoku sudoku; private Sudoku sudoku;
@ -23,6 +25,8 @@ public class SudokuUI extends JFrame {
// Création du bouton "Résoudre" // Création du bouton "Résoudre"
createSolveButton(); createSolveButton();
// Création des boutons "Charger" et "Générer"
createLoadButton();
createGenerateButton(); createGenerateButton();
// Calcul de la taille préférée de la fenêtre en fonction de la taille de la grille // Calcul de la taille préférée de la fenêtre en fonction de la taille de la grille
@ -80,6 +84,28 @@ public class SudokuUI extends JFrame {
add(buttonPanel, BorderLayout.SOUTH); add(buttonPanel, BorderLayout.SOUTH);
} }
private void createLoadButton() {
JButton loadButton = new JButton("Charger");
loadButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
JFileChooser fileChooser = new JFileChooser();
FileNameExtensionFilter filter = new FileNameExtensionFilter("Fichiers de grille Sudoku (*.gri)", "gri");
fileChooser.setFileFilter(filter);
int returnValue = fileChooser.showOpenDialog(null);
if (returnValue == JFileChooser.APPROVE_OPTION) {
File selectedFile = fileChooser.getSelectedFile();
sudoku.loadGridFromFile(selectedFile.getAbsolutePath());
updateGrid();
}
}
});
JPanel buttonPanel = new JPanel();
buttonPanel.add(loadButton);
add(buttonPanel, BorderLayout.NORTH);
}
private void createGenerateButton() { private void createGenerateButton() {
JButton generateButton = new JButton("Générer"); JButton generateButton = new JButton("Générer");
generateButton.addActionListener(new ActionListener() { generateButton.addActionListener(new ActionListener() {
@ -101,7 +127,6 @@ public class SudokuUI extends JFrame {
add(buttonPanel, BorderLayout.EAST); add(buttonPanel, BorderLayout.EAST);
} }
private void updateGrid() { private void updateGrid() {
Grid grid = sudoku.getGrid(); Grid grid = sudoku.getGrid();