03/01/2025 : Ajout des tests lignes, colonne et bloc

This commit is contained in:
ROGER
2025-01-03 16:35:02 +01:00
parent 7c29041ca4
commit a1b130b968
5 changed files with 333 additions and 143 deletions

View File

@@ -11,162 +11,162 @@ public class Grille {
private final Case[][] cases; private final Case[][] cases;
private final ArrayList<Bloc> blocs; private final ArrayList<Bloc> blocs;
private ArrayList<Symbole> symbolesPossibles; private ArrayList<Symbole> symbolesPossibles;
public Grille(int taille) { public Grille(int taille) {
this.taille = taille; this.taille = taille;
this.cases = new Case[taille][taille]; this.cases = new Case[taille][taille];
this.blocs = new ArrayList<>(); this.blocs = new ArrayList<>();
this.symbolesPossibles = new ArrayList<>(); this.symbolesPossibles = new ArrayList<>();
// Initialiser les cases // Initialiser les cases
for (int i = 0; i < taille; i++) { for (int i = 0; i < taille; i++) {
for (int j = 0; j < taille; j++) { for (int j = 0; j < taille; j++) {
cases[i][j] = new Case(i, j, null); cases[i][j] = new Case(i, j, null);
}
} }
} }
}
public void setCase(int ligne, int colonne, Symbole symbole) {
try { public void setCase(int ligne, int colonne, Symbole symbole) {
if (symbole != null && !symbolesPossibles.contains(symbole)) { try {
throw new IllegalArgumentException("Symbole non autorisé : " + symbole); if (symbole != null && !symbolesPossibles.contains(symbole)) {
} throw new IllegalArgumentException("Symbole non autorisé : " + symbole);
cases[ligne][colonne].setSymbole(symbole);
} catch (Exception e) {
Console.errorln(e.getMessage());
} }
cases[ligne][colonne].setSymbole(symbole);
} catch (Exception e) {
Console.errorln(e.getMessage());
} }
public Case getCase(int ligne, int colonne) { }
return cases[ligne][colonne];
public Case getCase(int ligne, int colonne) {
return cases[ligne][colonne];
}
/**
* Crée un bloc à partir des positions spécifiées
Exemple :
sudoku.getGrille().createBloc(Arrays.asList(
new int[] { 0, 0 },
new int[] { 0, 1 },
new int[] { 0, 2 },
new int[] { 1, 0 },
new int[] { 1, 1 },
new int[] { 1, 2 },
new int[] { 2, 0 },
new int[] { 2, 1 },
new int[] { 2, 2 }));
* @param positions
* @return
*/
public Bloc createBloc(List<int[]> positions) {
Bloc bloc = new Bloc();
for (int[] pos : positions) {
bloc.addCase(cases[pos[0]][pos[1]]);
} }
blocs.add(bloc);
/** return bloc;
* Crée un bloc à partir des positions spécifiées }
Exemple : public void createSquareBlocs() {
sudoku.getGrille().createBloc(Arrays.asList( try {
new int[] { 0, 0 }, int blocSize = (int) Math.sqrt(taille);
new int[] { 0, 1 }, if (blocSize * blocSize != taille) {
new int[] { 0, 2 }, throw new IllegalArgumentException("La taille de la grille doit être un carré parfait.");
new int[] { 1, 0 },
new int[] { 1, 1 },
new int[] { 1, 2 },
new int[] { 2, 0 },
new int[] { 2, 1 },
new int[] { 2, 2 }));
* @param positions
* @return
*/
public Bloc createBloc(List<int[]> positions) {
Bloc bloc = new Bloc();
for (int[] pos : positions) {
bloc.addCase(cases[pos[0]][pos[1]]);
} }
blocs.add(bloc); for (int i = 0; i < taille; i += blocSize) {
return bloc; for (int j = 0; j < taille; j += blocSize) {
} List<int[]> positions = new ArrayList<>();
for (int k = 0; k < blocSize; k++) {
public void createSquareBlocs() { for (int l = 0; l < blocSize; l++) {
try { positions.add(new int[] { i + k, j + l });
int blocSize = (int) Math.sqrt(taille);
if (blocSize * blocSize != taille) {
throw new IllegalArgumentException("La taille de la grille doit être un carré parfait.");
}
for (int i = 0; i < taille; i += blocSize) {
for (int j = 0; j < taille; j += blocSize) {
List<int[]> positions = new ArrayList<>();
for (int k = 0; k < blocSize; k++) {
for (int l = 0; l < blocSize; l++) {
positions.add(new int[] { i + k, j + l });
}
} }
createBloc(positions);
} }
createBloc(positions);
} }
} catch (IllegalArgumentException e) {
Console.errorln(e.getMessage());
} }
} catch (IllegalArgumentException e) {
Console.errorln(e.getMessage());
} }
}
// TO MOVE TO FUTUR CONSTRAINTS
// public boolean isValid() { // TO MOVE TO FUTUR CONSTRAINTS
// for (Bloc bloc : blocs) { // public boolean isValid() {
// if (!bloc.isValid()) { // for (Bloc bloc : blocs) {
// return false; // if (!bloc.isValid()) {
// } // return false;
// } // }
// return true; // }
// } // return true;
// }
public void printBlocs() {
for (Bloc bloc : blocs) { public void printBlocs() {
System.out.println(bloc.toString()); for (Bloc bloc : blocs) {
System.out.println(bloc.toString());
}
}
public void askSetSymbolesPossibles() {
try (Scanner scanner = new Scanner(System.in)) {
System.out.println(("Choisissez le type de symboles :"));
System.out.println(("1. Nombres"));
System.out.println(("2. Caractères"));
System.out.println(("3. Texte/Emoji"));
int choix = 0;
try {
choix = Integer.parseInt(scanner.nextLine());
} catch (NumberFormatException e) {
Console.errorln("Choix invalide");
return;
} }
}
for (int i = 0; i < taille; i++) {
public void askSetSymbolesPossibles() { System.out.println(("Entrez le symbole " + (i + 1) + "/" + taille + " :"));
try (Scanner scanner = new Scanner(System.in)) { String input = scanner.nextLine();
System.out.println(("Choisissez le type de symboles :"));
System.out.println(("1. Nombres")); switch (choix) {
System.out.println(("2. Caractères")); case 1: // Nombres
System.out.println(("3. Texte/Emoji")); try {
symbolesPossibles.add(Symbole.of(Integer.parseInt(input)));
int choix = 0; } catch (NumberFormatException e) {
try { Console.errorln("Veuillez entrer un nombre valide");
choix = Integer.parseInt(scanner.nextLine()); i--;
} catch (NumberFormatException e) { }
Console.errorln("Choix invalide"); break;
return;
} case 2: // Caractères
if (input.length() == 1) {
for (int i = 0; i < taille; i++) { symbolesPossibles.add(Symbole.of(input.charAt(0)));
System.out.println(("Entrez le symbole " + (i + 1) + "/" + taille + " :")); } else {
String input = scanner.nextLine(); Console.errorln("Veuillez entrer un seul caractère");
i--;
switch (choix) { }
case 1: // Nombres break;
try {
symbolesPossibles.add(Symbole.of(Integer.parseInt(input))); case 3: // Texte/Emoji
} catch (NumberFormatException e) { if (!input.isEmpty()) {
Console.errorln("Veuillez entrer un nombre valide"); symbolesPossibles.add(Symbole.of(input));
i--; } else {
} Console.errorln("Le symbole ne peut pas être vide");
break; i--;
}
case 2: // Caractères break;
if (input.length() == 1) {
symbolesPossibles.add(Symbole.of(input.charAt(0))); default:
} else { Console.errorln("Type non supporté");
Console.errorln("Veuillez entrer un seul caractère"); return;
i--;
}
break;
case 3: // Texte/Emoji
if (!input.isEmpty()) {
symbolesPossibles.add(Symbole.of(input));
} else {
Console.errorln("Le symbole ne peut pas être vide");
i--;
}
break;
default:
Console.errorln("Type non supporté");
return;
}
} }
} }
} }
}
public List<Symbole> getSymbolesPossibles() {
return symbolesPossibles; public List<Symbole> getSymbolesPossibles() {
} return symbolesPossibles;
}
public void setSymbolesPossibles(ArrayList<Symbole> symbolesPossibles) {
this.symbolesPossibles = symbolesPossibles; public void setSymbolesPossibles(ArrayList<Symbole> symbolesPossibles) {
this.symbolesPossibles = symbolesPossibles;
} }
public void printSymbolesPossibles() { public void printSymbolesPossibles() {

View File

@@ -5,13 +5,51 @@ package sudoku;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.Arrays;
import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertEquals;
public class AppTest { public class AppTest {
@Test @Test
public void testExample() { public void testExample() {
//Grille.askSetSymbolesPossibles();
System.out.println("DOING TEST"); System.out.println("DOING TEST");
assertEquals(2 + 2, 4); System.out.println(new App().getGreeting());
System.out.println("DONE TEST");
// Create a new Sudoku
Sudoku sudoku = new Sudoku(9);
sudoku.getGrille().setSymbolesPossibles(new ArrayList<>(Arrays.asList(
Symbole.of(1),
Symbole.of(2),
Symbole.of(3),
Symbole.of(4),
Symbole.of(5),
Symbole.of(6),
Symbole.of(7),
Symbole.of(8),
Symbole.of(9))));
sudoku.getGrille().setCase(0, 0, Symbole.of(1));
sudoku.getGrille().setCase(6, 1, Symbole.of(2));
sudoku.getGrille().setCase(2, 2, Symbole.of(3));
sudoku.getGrille().setCase(0, 3, Symbole.of(4));
sudoku.getGrille().setCase(4, 4, Symbole.of(5));
sudoku.getGrille().setCase(0, 5, Symbole.of(6));
sudoku.getGrille().setCase(5, 6, Symbole.of(7));
sudoku.getGrille().setCase(0, 7, Symbole.of(8));
sudoku.getGrille().setCase(4, 8, Symbole.of(9));
sudoku.getGrille().createSquareBlocs();
System.out.println("Sudoku :");
System.out.println(sudoku.getGrille().toString());
System.out.println("Blocs :");
sudoku.getGrille().printBlocs();
System.out.println("Symboles possibles :");
sudoku.getGrille().printSymbolesPossibles();
System.out.println("DONE TEST");
} }
} }

View File

@@ -0,0 +1,50 @@
package sudoku;
import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.Arrays;
public class TestBloc {
@Test
public void testBloc() {
System.out.println("TEST BLOC : ");
System.out.println(new App().getGreeting());
// Create a new Sudoku
Sudoku sudoku = new Sudoku(9);
sudoku.getGrille().setSymbolesPossibles(new ArrayList<>(Arrays.asList(
Symbole.of(1),
Symbole.of(2),
Symbole.of(3),
Symbole.of(4),
Symbole.of(5),
Symbole.of(6),
Symbole.of(7),
Symbole.of(8),
Symbole.of(9))));
sudoku.getGrille().setCase(0, 0, Symbole.of(1));
sudoku.getGrille().setCase(6, 1, Symbole.of(2));
sudoku.getGrille().setCase(2, 2, Symbole.of(3));
sudoku.getGrille().setCase(0, 3, Symbole.of(4));
sudoku.getGrille().setCase(4, 4, Symbole.of(5));
sudoku.getGrille().setCase(0, 5, Symbole.of(6));
sudoku.getGrille().setCase(5, 6, Symbole.of(7));
sudoku.getGrille().setCase(0, 7, Symbole.of(8));
sudoku.getGrille().setCase(4, 8, Symbole.of(9));
//doublon ligne
sudoku.getGrille().setCase(0, 1, Symbole.of(1));
sudoku.getGrille().createSquareBlocs();
System.out.println("Sudoku :");
System.out.println(sudoku.getGrille().toString());
System.out.println("Blocs :");
sudoku.getGrille().printBlocs();
System.out.println("Symboles possibles :");
sudoku.getGrille().printSymbolesPossibles();
System.out.println("FIN TEST BLOC");
}
}

View File

@@ -0,0 +1,52 @@
package sudoku;
import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.Arrays;
import static org.junit.jupiter.api.Assertions.assertEquals;
public class TestColonne {
@Test
public void testColonne() {
System.out.println("TEST COL : ");
System.out.println(new App().getGreeting());
// Create a new Sudoku
Sudoku sudoku = new Sudoku(9);
sudoku.getGrille().setSymbolesPossibles(new ArrayList<>(Arrays.asList(
Symbole.of(1),
Symbole.of(2),
Symbole.of(3),
Symbole.of(4),
Symbole.of(5),
Symbole.of(6),
Symbole.of(7),
Symbole.of(8),
Symbole.of(9))));
sudoku.getGrille().setCase(0, 0, Symbole.of(1));
sudoku.getGrille().setCase(6, 1, Symbole.of(2));
sudoku.getGrille().setCase(2, 2, Symbole.of(3));
sudoku.getGrille().setCase(0, 3, Symbole.of(4));
sudoku.getGrille().setCase(4, 4, Symbole.of(5));
sudoku.getGrille().setCase(0, 5, Symbole.of(6));
sudoku.getGrille().setCase(5, 6, Symbole.of(7));
sudoku.getGrille().setCase(0, 7, Symbole.of(8));
sudoku.getGrille().setCase(4, 8, Symbole.of(9));
//doublon ligne
sudoku.getGrille().setCase(0, 0, Symbole.of(1));
sudoku.getGrille().createSquareBlocs();
System.out.println("Sudoku :");
System.out.println(sudoku.getGrille().toString());
System.out.println("Blocs :");
sudoku.getGrille().printBlocs();
System.out.println("Symboles possibles :");
sudoku.getGrille().printSymbolesPossibles();
System.out.println("FIN TEST COL");
}
}

View File

@@ -0,0 +1,50 @@
package sudoku;
import org.junit.jupiter.api.Test;
import java.util.ArrayList;
import java.util.Arrays;
public class TestLigne {
@Test
public void testLigne() {
System.out.println("TEST LIGNE : ");
System.out.println(new App().getGreeting());
// Create a new Sudoku
Sudoku sudoku = new Sudoku(9);
sudoku.getGrille().setSymbolesPossibles(new ArrayList<>(Arrays.asList(
Symbole.of(1),
Symbole.of(2),
Symbole.of(3),
Symbole.of(4),
Symbole.of(5),
Symbole.of(6),
Symbole.of(7),
Symbole.of(8),
Symbole.of(9))));
sudoku.getGrille().setCase(0, 0, Symbole.of(1));
sudoku.getGrille().setCase(6, 1, Symbole.of(2));
sudoku.getGrille().setCase(2, 2, Symbole.of(3));
sudoku.getGrille().setCase(0, 3, Symbole.of(4));
sudoku.getGrille().setCase(4, 4, Symbole.of(5));
sudoku.getGrille().setCase(0, 5, Symbole.of(6));
sudoku.getGrille().setCase(5, 6, Symbole.of(7));
sudoku.getGrille().setCase(0, 7, Symbole.of(8));
sudoku.getGrille().setCase(4, 8, Symbole.of(9));
//doublon ligne
sudoku.getGrille().setCase(0, 4, Symbole.of(1));
sudoku.getGrille().createSquareBlocs();
System.out.println("Sudoku :");
System.out.println(sudoku.getGrille().toString());
System.out.println("Blocs :");
sudoku.getGrille().printBlocs();
System.out.println("Symboles possibles :");
sudoku.getGrille().printSymbolesPossibles();
System.out.println("FIN TEST LIGNE");
}
}