diff options
author | Aineopintojen-harjoitustyo-Algoritmit-j <github-hy-tiralabra@v.hix.fi> | 2024-01-29 03:40:19 +0200 |
---|---|---|
committer | Aineopintojen-harjoitustyo-Algoritmit-j <github-hy-tiralabra@v.hix.fi> | 2024-01-29 03:40:19 +0200 |
commit | 2b2117ec7bf75ad5ba37cc5b21870d073cb405a4 (patch) | |
tree | f8493d8b8da726e99f4a819ea7963b94b305dfb5 /bots/dssp.py | |
parent | e591d15abc4943a74c39f0fcab065213828a1514 (diff) |
Fixing guessing to use all bordering number tiles.
Diffstat (limited to 'bots/dssp.py')
-rw-r--r-- | bots/dssp.py | 16 |
1 files changed, 7 insertions, 9 deletions
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] |