загружаю файл с тестированием
This commit is contained in:
parent
0210d7f31e
commit
3db797a56d
|
@ -2,24 +2,22 @@ from main import ShootResult
|
|||
|
||||
|
||||
class ShipField:
|
||||
field = [' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ']
|
||||
|
||||
field_size = 10
|
||||
field_mode = 0
|
||||
ship_size = 4
|
||||
ship_direction = 0
|
||||
|
||||
def __init__(self):
|
||||
pass
|
||||
self.field = [' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
|
||||
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ']
|
||||
|
||||
self.field_size = 10
|
||||
self.field_mode = 0
|
||||
self.ship_size = 4
|
||||
self.ship_direction = 0
|
||||
|
||||
def set_ship(self, row, col):
|
||||
if row < 0 or row > self.field_size:
|
||||
|
@ -56,13 +54,13 @@ class ShipField:
|
|||
return ShootResult.UNDEFINED
|
||||
|
||||
def check_possible(self, row, col, ship_size, ship_direction):
|
||||
# Функция должна возвращать True, если можно поставить сюда корабль,
|
||||
# в противном случае - False
|
||||
# Функция должна возвращать True, если можно поставить сюда корабль,
|
||||
# в противном случае - False
|
||||
|
||||
if self.ship_direction == 0:
|
||||
# Здесь мы знаем, что корабль помещается на поле.
|
||||
# Здесь мы знаем, что корабль помещается на поле.
|
||||
if self.field_size - row >= self.ship_size:
|
||||
# Теперь нужно проверить, не заблокировано ли какое-то из полей,
|
||||
# Теперь нужно проверить, не заблокировано ли какое-то из полей,
|
||||
for r in range(row, row + self.ship_size):
|
||||
if not self.check_blocked(self, r, col):
|
||||
return False
|
||||
|
@ -78,8 +76,8 @@ class ShipField:
|
|||
return False
|
||||
|
||||
def check_blocked(self, row, col):
|
||||
# Функция возвращает True, если все клетки вокруг клетки с координатами row, col
|
||||
# либо находятся за пределами поля, либо в них нет корабля/они пустые
|
||||
# Функция возвращает True, если все клетки вокруг клетки с координатами row, col
|
||||
# либо находятся за пределами поля, либо в них нет корабля/они пустые
|
||||
for r in range(row - 1, row + 2):
|
||||
for c in range(col - 1, col + 2):
|
||||
if 0 <= r < self.field_size and 0 <= c < self.field_size:
|
||||
|
@ -89,10 +87,10 @@ class ShipField:
|
|||
return True
|
||||
|
||||
def set_ship_size(self, value):
|
||||
if value.isnumeric():
|
||||
number = int(value)
|
||||
if 1 <= number <= 4:
|
||||
self.ship_size = number
|
||||
if value.isnumeric():
|
||||
number = int(value)
|
||||
if 1 <= number <= 4:
|
||||
self.ship_size = number
|
||||
|
||||
def set_ship_direction(self, value):
|
||||
if value.isnumeric() == 0 or value.isnumeric() == 1:
|
||||
|
@ -113,6 +111,3 @@ class ShipField:
|
|||
ship_string += self.field[r * self.field_size + c] + ', '
|
||||
print(blocked_string[:-2] + ' ' + ship_string[:-2])
|
||||
print("********************************************************************")
|
||||
|
||||
|
||||
|
|
@ -1,8 +1,48 @@
|
|||
from main import ShootResult
|
||||
from ShipField import ShipField
|
||||
|
||||
ship_field = ShipField()
|
||||
ship_field.set_ship_size(3)
|
||||
ship_field.set_ship_direction(0)
|
||||
ship_field.set_ship(1, 1)
|
||||
ship_field.print_field()
|
||||
|
||||
def verify_value(actual, expected):
|
||||
if actual == expected:
|
||||
print("OK")
|
||||
else:
|
||||
print("ERROR")
|
||||
|
||||
|
||||
my_field = ShipField()
|
||||
|
||||
print("set_ship_size()")
|
||||
my_field.set_ship_size(1)
|
||||
verify_value(my_field.set_ship_size, 1)
|
||||
|
||||
my_field.set_ship_size(0)
|
||||
my_field.set_ship_size(6)
|
||||
verify_value(my_field.set_ship_size, 1)
|
||||
|
||||
my_field.set_ship_size([])
|
||||
my_field.set_ship_size("")
|
||||
my_field.set_ship_size(None)
|
||||
my_field.set_ship_size(True)
|
||||
my_field.set_ship_size(False)
|
||||
verify_value(my_field.set_ship_size, 1)
|
||||
|
||||
my_field.set_ship_size("2")
|
||||
verify_value(my_field.set_ship_size, 2)
|
||||
print()
|
||||
|
||||
print('toggle_field_mode()')
|
||||
verify_value(my_field.field_mode, 0)
|
||||
|
||||
my_field.toggle_field_mode()
|
||||
verify_value(my_field.field_mode, 1)
|
||||
|
||||
my_field.toggle_field_mode()
|
||||
verify_value(my_field.field_mode, 0)
|
||||
print()
|
||||
|
||||
print("ship_set()")
|
||||
verify_value(my_field.field[0], " ")
|
||||
|
||||
my_field.set_ship_size(1)
|
||||
my_field.ship_direction(0)
|
||||
my_field.set_ship(0, 0)
|
||||
|
||||
|
|
Binary file not shown.
Binary file not shown.
|
@ -290,7 +290,7 @@ print(len(enemy_buttons))
|
|||
lbl = Label(window, text='', width=5, height=2)
|
||||
lbl.grid(column=10, row=0)
|
||||
|
||||
window.mainloop()
|
||||
#window.mainloop()
|
||||
|
||||
|
||||
for r in range(0, field_size):
|
||||
|
|
Loading…
Reference in New Issue