variable to store last move added for AI moves

This commit is contained in:
LinlyBoi
2023-05-05 21:59:38 +03:00
parent bd5daa17f1
commit c8be17a26a

View File

@@ -13,6 +13,7 @@ pub struct Board {
red_score: i32, red_score: i32,
blu_score: i32, blu_score: i32,
columns: Array2D<Disk>, columns: Array2D<Disk>,
last_move: usize,
} }
impl Default for Board { impl Default for Board {
@@ -23,6 +24,7 @@ impl Default for Board {
red_score: 0, red_score: 0,
blu_score: 0, blu_score: 0,
columns, columns,
last_move: 0,
} }
} }
} }
@@ -34,11 +36,12 @@ impl Board {
fn play(&mut self, disk: Disk, col: usize) -> bool { fn play(&mut self, disk: Disk, col: usize) -> bool {
let column = &self.columns.as_columns()[col as usize]; let column = &self.columns.as_columns()[col as usize];
let empty = column.iter().filter(|&a| matches!(a, Disk::EMPTY)).count(); let empty = column.iter().filter(|&a| matches!(a, Disk::EMPTY)).count();
dbg!(empty); // dbg!(empty);
let top = column.len() - empty; let top = column.len() - empty;
match self.columns.set(top, col as usize, disk) { match self.columns.set(top, col as usize, disk) {
Ok(_) => { Ok(_) => {
self.score_check((top, col)); self.score_check((top, col));
self.last_move = col;
true true
} }
Err(_) => false, Err(_) => false,
@@ -97,6 +100,17 @@ impl Board {
.count() .count()
== 0 == 0
} }
fn get_children(&self, disk: Disk) -> Vec<Board> {
let mut children: Vec<Board> = vec![];
for column in 0..self.columns.num_columns() {
let mut child = self.clone();
match child.play(disk, column) {
true => children.push(child),
false => {}
}
}
children
}
} }
#[derive(Copy, Clone, Debug, PartialEq, Eq)] #[derive(Copy, Clone, Debug, PartialEq, Eq)]
@@ -105,3 +119,10 @@ pub enum Disk {
BLU, BLU,
EMPTY, EMPTY,
} }
pub fn flip_disk(disk: Disk) -> Disk {
match disk {
Disk::RED => Disk::BLU,
Disk::BLU => Disk::RED,
Disk::EMPTY => Disk::EMPTY, //why..just why
}
}