From 2b2117ec7bf75ad5ba37cc5b21870d073cb405a4 Mon Sep 17 00:00:00 2001 From: Aineopintojen-harjoitustyo-Algoritmit-j Date: Mon, 29 Jan 2024 03:40:19 +0200 Subject: Fixing guessing to use all bordering number tiles. --- bots/dssp.py | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) (limited to 'bots/dssp.py') diff --git a/bots/dssp.py b/bots/dssp.py index 33578a0..78dec8e 100644 --- a/bots/dssp.py +++ b/bots/dssp.py @@ -54,22 +54,20 @@ class DSSPBot(SimpleBot): return self.saved_hints() def lucky_guess(self): - heatmap = dict.fromkeys(self.get_unknown_tiles(), 0) - tiles = self.get_interesting_tiles() + heatmap = dict.fromkeys(self.get_unknown_tiles(), float(0)) + tiles = self.get_border_tiles() for tile in tiles: n = self.get_neighbours(tile) c = self.get_value(tile) - self.remove_bomb_tiles(n) self.remove_number_tiles(n) - for tile in n: - heatmap[tile] = max( heatmap[tile], c/len(n) ) + for ntile in n: + heatmap[ntile] += c/len(n) - for tile, value in heatmap.items(): - if value>0: - continue + for tile in heatmap: if tile[0] in range(1,self.w-1): - heatmap[tile]+=0.05 + heatmap[tile]+=0.005 if tile[1] in range(1,self.h-1): - heatmap[tile]+=0.05 + heatmap[tile]+=0.005 best = min((x for _, x in heatmap.items())) best_tiles = [x for x,y in heatmap.items() if y == best] -- cgit v1.2.3