pub struct DiagonallyAdjacentConstraint;
Expand description
A RelativeCellConstraint that excludes duplicates in a diagonally adjacent cell to the reference cell. If normal Sudoku rules apply, this is equivalent to a KingsMoveConstraint.
As a visualization, the cells marked with ‘X’ in the following grid are excluded from being a 3:
┌───┬───┬───┐
│ X │ │ X │
├───┼───┼───┤
│ │ 3 │ │
├───┼───┼───┤
│ X │ │ X │
└───┴───┴───┘
Trait Implementations§
Source§impl Clone for DiagonallyAdjacentConstraint
impl Clone for DiagonallyAdjacentConstraint
Source§fn clone(&self) -> DiagonallyAdjacentConstraint
fn clone(&self) -> DiagonallyAdjacentConstraint
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl RelativeCellConstraint for DiagonallyAdjacentConstraint
impl RelativeCellConstraint for DiagonallyAdjacentConstraint
Source§const RELATIVE_COORDINATES: &'static [(isize, isize)]
const RELATIVE_COORDINATES: &'static [(isize, isize)]
A slice of coordinates relative to the cell in question that must not
contain the same number.
Source§fn is_forbidden(&self, reference_cell: usize, other_cell: usize) -> bool
fn is_forbidden(&self, reference_cell: usize, other_cell: usize) -> bool
Given the contents of the reference cell and one other cell that is
removed by one set of coordinates specified in
RelativeCellConstraint::RELATIVE_COORDINATES, this method determines
whether the reference cell violates the constraint. Since it is assumed
that an empty cell cannot violate the constraint, this method is only
called if both cells contain a number. Read more
Auto Trait Implementations§
impl Freeze for DiagonallyAdjacentConstraint
impl RefUnwindSafe for DiagonallyAdjacentConstraint
impl Send for DiagonallyAdjacentConstraint
impl Sync for DiagonallyAdjacentConstraint
impl Unpin for DiagonallyAdjacentConstraint
impl UnwindSafe for DiagonallyAdjacentConstraint
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<C> CloneConstraint for Cwhere
C: Constraint + Clone + 'static,
impl<C> CloneConstraint for Cwhere
C: Constraint + Clone + 'static,
Source§fn clone_box(&self) -> Box<dyn CloneConstraint>
fn clone_box(&self) -> Box<dyn CloneConstraint>
Clones a trait object of this constraint.
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<C> Constraint for Cwhere
C: RelativeCellConstraint,
impl<C> Constraint for Cwhere
C: RelativeCellConstraint,
Source§fn check_number(
&self,
grid: &SudokuGrid,
column: usize,
row: usize,
number: usize,
) -> bool
fn check_number( &self, grid: &SudokuGrid, column: usize, row: usize, number: usize, ) -> bool
Checks whether the given
number
would fit into the cell specified by
column
and row
into the grid
without violating this constraint.
This function does not have to check whether number
is actually a
valid number for this grid (i.e. in the interval [1, size]). If you
require this guarantee, use
Sudoku::is_valid_number instead. Read moreSource§fn get_groups(&self, _: &SudokuGrid) -> Vec<Vec<(usize, usize)>>
fn get_groups(&self, _: &SudokuGrid) -> Vec<Vec<(usize, usize)>>
Gets a vector of all groups that are defined by this constraint. A
group is a set of cells which may not contain repeated numbers. As an
example, the BlockConstraint defines each block as a group. Some
constraints, such as the KingsMoveConstraint, do not have groups. In
this particular case, a cell removed by a kings-move to the top-left
may be the same as one to the bottom-right, so the cells removed by a
kings-move from any particular cell cannot form a group. Such
constraints should return an empty vector here. Read more
Source§fn check(&self, grid: &SudokuGrid) -> bool
fn check(&self, grid: &SudokuGrid) -> bool
Checks whether the given SudokuGrid matches this constraint, that is,
every cell matches this constraint. By default, this runs
check_cell
on every cell of the grid, which may be inefficient, so custom
implementations may be advantageous.Source§fn check_cell(&self, grid: &SudokuGrid, column: usize, row: usize) -> bool
fn check_cell(&self, grid: &SudokuGrid, column: usize, row: usize) -> bool
Checks whether the cell at the given position in the SudokuGrid
fulfills the constraint. This is the same as calling
check_number
with the same coordinates and the number which is actually filled in
that cell. If the cell is empty, this function always returns true
.