summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README.md7
-rw-r--r--__main__.py3
-rw-r--r--app.py8
-rw-r--r--bots/bad.py14
-rw-r--r--bots/bot.py3
5 files changed, 28 insertions, 7 deletions
diff --git a/README.md b/README.md
index c88803e..0be8738 100644
--- a/README.md
+++ b/README.md
@@ -7,8 +7,15 @@ Miinaharava ratkaisijalla
- [määrittelydokumentti](doc/m%C3%A4%C3%A4rittelydokumentti.pdf)
## Ohjeet:
+
+### Asenna
`git clone https://github.com/Aineopintojen-harjoitustyo-Algoritmit-j/miinaharava`
+### Aja
`python3 miinaharava`
+### Käyttöohjeet
`python3 miinaharava -h`
+
+### Automaattipelin suoritusesimerkki
+`python3 miinaharava -i -a -u`
diff --git a/__main__.py b/__main__.py
index 697ceb4..edf3888 100644
--- a/__main__.py
+++ b/__main__.py
@@ -32,9 +32,6 @@ parser.add_argument(
action='store_true'
)
-
-
-
args = parser.parse_args()
app = App(args)
diff --git a/app.py b/app.py
index 6a2b00a..be44752 100644
--- a/app.py
+++ b/app.py
@@ -8,16 +8,18 @@ from bots import BadBot
class App:
""" App - Luokka pääohjelmalle"""
def __init__(self, args=None):
- level=Level.BEGINNER
- ui_class=Tui
+ level = Level.BEGINNER
+ ui_class = Tui
+ uncertain = False
if args:
level = Level.EXPERT if args.expert else level
level = Level.INTERMEDIATE if args.intermediate else level
level = Level.BEGINNER if args.beginner else level
ui_class = AutoTui if args.auto else ui_class
+ uncertain = args.uncertain
self.board = Board(level=level)
- self.bot = BadBot()
+ self.bot = BadBot(uncertain=uncertain)
self.ui = ui_class(self.bot)
self.game = Game(self.board,self.ui)
diff --git a/bots/bad.py b/bots/bad.py
index fb853f1..5197dc9 100644
--- a/bots/bad.py
+++ b/bots/bad.py
@@ -1,4 +1,5 @@
""" bots/bad.py - botti joka ehkä osaa merkata jonkun asian """
+from random import sample
from tui import Action
from .bot import Bot
@@ -37,6 +38,16 @@ class BadBot(Bot):
tiles.append( (x,y) )
return tiles
+ def get_unopened_tiles(self, matrix):
+ """ get interesting tiles on the border of cleared and masked area """
+ tiles = []
+ w = len(matrix)
+ h = len(matrix[0])
+ for y in range(h):
+ for x in range(w):
+ if matrix[x][y] == 12:
+ tiles.append( (x,y) )
+ return tiles
def hint(self, matrix, cursor_x, cursor_y):
""" merkitsee jonkin ruudun """
@@ -56,4 +67,7 @@ class BadBot(Bot):
if matrix[x][y]-bombs==unopened:
bomb = ncoords[ntiles.index(12)]
return(Action.BOMB, bomb[0], bomb[1])
+ if self.uncertain:
+ x, y = sample(self.get_unopened_tiles(matrix),1)[0]
+ return (Action.OPEN, x, y)
return (Action.NOOP, cursor_x, cursor_y)
diff --git a/bots/bot.py b/bots/bot.py
index a097a8d..5ad0bd2 100644
--- a/bots/bot.py
+++ b/bots/bot.py
@@ -3,7 +3,8 @@ from tui import Action
class Bot():
""" Bot - perusluokka perittäväksi """
- def __init__(self):
+ def __init__(self, **opts):
+ self.uncertain = opts['uncertain'] if 'uncertain' in opts else False
self.hints = 0
def neighbours(self,dx,dy,x,y):