From dca833cd9a62e163f300572ed0b3ec0dd63aa123 Mon Sep 17 00:00:00 2001 From: Aineopintojen-harjoitustyo-Algoritmit-j Date: Sat, 13 Jan 2024 12:36:30 +0200 Subject: Refactoring free area collection to use neigbours function. --- board/board.py | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/board/board.py b/board/board.py index 741edf6..2d3fa1f 100644 --- a/board/board.py +++ b/board/board.py @@ -37,14 +37,17 @@ class Board(): def invalid_coordinates(self, x, y): return x < 0 or x >= self.size or y < 0 or y >= self.size - def get_neighbours_coords(self, x, y, coordinates = None): - if not coordinates: - coordinates=[] + def get_neighbours_coords(self, x, y, include_home = False): offsets = ( + (-1,-1), (0,-1), (1,-1), + (-1, 0), (0, 0), (1, 0), + (-1, 1), (0, 1), (1, 1) + ) if include_home else ( (-1,-1), (0,-1), (1,-1), (-1, 0), (1, 0), (-1, 1), (0, 1), (1, 1) ) + coordinates=[] for dx,dy in offsets: if not self.invalid_coordinates(x+dx, y+dy): coordinates.append( (x+dx, y+dy) ) @@ -81,12 +84,10 @@ class Board(): if not area: area.add((x,y)) to_test = [] - for dx, dy in ( (0,-1), (-1,0), (1,0), (0,1) ): - if self.invalid_coordinates(x+dx, y+dy): - continue - if self.tiles[x+dx][y+dy] == 0 and (x+dx,y+dy) not in area: - to_test.append((x+dx, y+dy)) - area.add((x+dx, y+dy)) + for nx, ny in self.get_neighbours_coords(x, y): + if self.tiles[nx][ny] == 0 and (nx,ny) not in area: + to_test.append((nx, ny)) + area.add((nx, ny)) for tx, ty in to_test: area=area.union(self.collect_area(tx, ty, area)) return area @@ -110,7 +111,7 @@ class Board(): if self.tiles[x][y] == 0: for cx, cy in self.collect_area( x, y ): - for nx, ny in self.get_neighbours_coords(cx, cy, [(0,0)]): + for nx, ny in self.get_neighbours_coords(cx, cy, True): self.masked[nx][ny] = 0 return True -- cgit v1.2.3