Gwendal in main : add test on futur constraints and enhance input symbol method #1
@@ -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() {
|
||||||
|
|||||||
@@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
50
app/src/test/java/sudoku/TestBloc.java
Normal file
50
app/src/test/java/sudoku/TestBloc.java
Normal 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");
|
||||||
|
}
|
||||||
|
}
|
||||||
52
app/src/test/java/sudoku/TestColonne.java
Normal file
52
app/src/test/java/sudoku/TestColonne.java
Normal 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");
|
||||||
|
}
|
||||||
|
}
|
||||||
50
app/src/test/java/sudoku/TestLigne.java
Normal file
50
app/src/test/java/sudoku/TestLigne.java
Normal 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");
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user