refractoring
All checks were successful
Linux arm64 / Build (push) Successful in 33s

This commit is contained in:
Janet-Doe
2025-01-21 13:49:22 +01:00
parent 5a07f9347c
commit e5618b70c1
8 changed files with 60 additions and 36 deletions

View File

@@ -3,11 +3,11 @@ package sudoku;
public abstract class Cell { public abstract class Cell {
protected static int NOSYMBOLE = -1; protected static int NOSYMBOLE = -1;
protected int symboleIndex; protected int symbolIndex;
protected Block block = null; protected Block block = null;
public Cell(int symboleIndex) { public Cell(int symbolIndex) {
this.symboleIndex = symboleIndex; this.symbolIndex = symbolIndex;
} }
/** /**
@@ -17,8 +17,8 @@ public abstract class Cell {
this(NOSYMBOLE); this(NOSYMBOLE);
} }
public int getSymboleIndex() { public int getSymbolIndex() {
return symboleIndex; return symbolIndex;
} }
public Block getBlock() { public Block getBlock() {
@@ -33,7 +33,7 @@ public abstract class Cell {
@Override @Override
public boolean equals(Object obj) { public boolean equals(Object obj) {
if (obj instanceof Cell otherCell) if (obj instanceof Cell otherCell)
return otherCell.getSymboleIndex() == this.getSymboleIndex(); return otherCell.getSymbolIndex() == this.getSymbolIndex();
return false; return false;
} }
} }

View File

@@ -5,38 +5,38 @@ import java.util.List;
public class MutableCell extends Cell{ public class MutableCell extends Cell{
private final List<Integer> hintsSymbolIndex; private final List<Integer> possibleSymbols;
public MutableCell() { public MutableCell() {
super(); super();
this.hintsSymbolIndex = new ArrayList<>(); this.possibleSymbols = new ArrayList<>();
} }
public MutableCell(int symboleIndex) { public MutableCell(int symbolIndex) {
super(symboleIndex); super(symbolIndex);
this.hintsSymbolIndex = new ArrayList<>(); this.possibleSymbols = new ArrayList<>();
} }
public void setSymboleIndex(int symboleIndex) { public void setSymbolIndex(int symbolIndex) {
this.symboleIndex = symboleIndex; this.symbolIndex = symbolIndex;
} }
/** /**
* Remove the current symboleIndex and returns it * Remove the current symbolIndex and returns it
* @return integer symboleIndex cleared * @return integer symbolIndex cleared
*/ */
public int clear() { public int clearCurrentSymbol() {
int i = this.symboleIndex; int i = this.symbolIndex;
setSymboleIndex(NOSYMBOLE); setSymbolIndex(NOSYMBOLE);
return i; return i;
} }
public void removeHint(int indexSymbol) { public void removeSymbolFromPossibilities(int indexSymbol) {
hintsSymbolIndex.remove(indexSymbol); possibleSymbols.remove(indexSymbol);
} }
public List<Integer> getHints() { public List<Integer> getPossibleSymbols() {
return this.hintsSymbolIndex; return this.possibleSymbols;
} }
} }

View File

@@ -14,10 +14,12 @@ public class Sudoku {
private final List<Block> blocks; private final List<Block> blocks;
private final List<Cell> cells; private final List<Cell> cells;
private final List<IConstraint> constraints;
public Sudoku(List<Cell> cells, List<Block> blocks) { public Sudoku(List<Cell> cells, List<Block> blocks, List<IConstraint> constraints) {
this.cells = cells; this.cells = cells;
this.blocks = blocks; this.blocks = blocks;
this.constraints = new ArrayList<>(constraints);
} }
public Cell getCell(int x, int y) { public Cell getCell(int x, int y) {
@@ -30,6 +32,10 @@ public class Sudoku {
return this.cells.get(i); return this.cells.get(i);
} }
public List<IConstraint> getConstraints() {
return constraints;
}
public int getSize() { public int getSize() {
return this.blocks.size(); return this.blocks.size();
} }

View File

@@ -1,5 +1,10 @@
package sudoku; package sudoku;
import sudoku.constraint.BlockConstraint;
import sudoku.constraint.ColumnConstraint;
import sudoku.constraint.IConstraint;
import sudoku.constraint.LineConstraint;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
@@ -37,10 +42,14 @@ public class SudokuFactory {
int symbolCount = width * height; int symbolCount = width * height;
List<Cell> cases = initCells(symbolCount); List<Cell> cases = initCells(symbolCount);
List<Block> blocs = initRectangleBlocs(cases, width, height); List<Block> blocs = initRectangleBlocs(cases, width, height);
Sudoku s = new Sudoku(cases, blocs); List<IConstraint> constraints = new ArrayList<>();
List<Sudoku> ss = new ArrayList<>(); constraints.add(new ColumnConstraint());
ss.add(s); constraints.add(new LineConstraint());
return new MultiDoku(ss); constraints.add(new BlockConstraint());
Sudoku s = new Sudoku(cases, blocs, constraints);
List<Sudoku> subSudoku = new ArrayList<>();
subSudoku.add(s);
return new MultiDoku(subSudoku);
} }
public static MultiDoku createBasicEmptySquareSudoku(int size) { public static MultiDoku createBasicEmptySquareSudoku(int size) {

View File

@@ -2,6 +2,7 @@ package sudoku.constraint;
import sudoku.Block; import sudoku.Block;
import sudoku.Cell; import sudoku.Cell;
import sudoku.MutableCell;
import sudoku.Sudoku; import sudoku.Sudoku;
public class BlockConstraint implements IConstraint{ public class BlockConstraint implements IConstraint{
@@ -9,7 +10,7 @@ public class BlockConstraint implements IConstraint{
@Override @Override
public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) { public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) {
Block bloc = s.getCell(x, y).getBlock(); Block bloc = s.getCell(x, y).getBlock();
return !bloc.getCells().contains(new Cell(newSymbolIndex)); return !bloc.getCells().contains(new MutableCell(newSymbolIndex));
} }
} }

View File

@@ -7,7 +7,7 @@ public class ColumnConstraint implements IConstraint {
@Override @Override
public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) { public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) {
for (int i = 0; i < s.getSize(); i++) { for (int i = 0; i < s.getSize(); i++) {
if (s.getCell(x, newSymbolIndex).getSymboleIndex() == newSymbolIndex) if (s.getCell(x, newSymbolIndex).getSymbolIndex() == newSymbolIndex)
return false; return false;
} }
return true; return true;

View File

@@ -7,7 +7,7 @@ public class LineConstraint implements IConstraint {
@Override @Override
public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) { public boolean canBePlaced(final Sudoku s, int x, int y, int newSymbolIndex) {
for (int i = 0; i < s.getSize(); i++) { for (int i = 0; i < s.getSize(); i++) {
if (s.getCell(newSymbolIndex, y).getSymboleIndex() == newSymbolIndex) if (s.getCell(newSymbolIndex, y).getSymbolIndex() == newSymbolIndex)
return false; return false;
} }
return true; return true;

View File

@@ -1,17 +1,16 @@
package sudoku.solver; package sudoku.solver;
import sudoku.Cell;
import sudoku.MultiDoku; import sudoku.MultiDoku;
import sudoku.MutableCell; import sudoku.MutableCell;
import sudoku.Sudoku;
import sudoku.constraint.IConstraint; import sudoku.constraint.IConstraint;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Random; import java.util.Random;
import java.util.Stack;
public class Solver { public class Solver {
Caretaker stack; Stack<MutableCell> stack;
public Solver() { public Solver() {
} }
@@ -26,12 +25,21 @@ public class Solver {
while (!remainingCellsToCheck.isEmpty()) { while (!remainingCellsToCheck.isEmpty()) {
int indexCurrentCell = rand.nextInt(remainingCellsToCheck.size()); int indexCurrentCell = rand.nextInt(remainingCellsToCheck.size());
MutableCell currentCell = remainingCellsToCheck.get(indexCurrentCell); MutableCell currentCell = remainingCellsToCheck.get(indexCurrentCell);
if (currentCell.getHints().isEmpty()){ if (currentCell.getPossibleSymbols().isEmpty()){
MutableCell modify = stack.undo(); MutableCell modify = stack.pop();
modify.removeHint(modify.clear()); modify.removeSymbolFromPossibilities(modify.clearCurrentSymbol());
} else {
int symbol = currentCell.getPossibleSymbols().get(0);
currentCell.setSymbolIndex(symbol);
stack.push(currentCell);
//TODO check constraints integrity in sudoku
} }
remainingCellsToCheck.remove(indexCurrentCell); remainingCellsToCheck.remove(indexCurrentCell);
} }
return doku; return doku;