[1] Лабораторная работа №1 "Структуры данных" #198

Merged
kit8nino merged 18 commits from stepushovgs/2026-rff_mp:stepushovgs into develop 2026-05-30 11:41:24 +00:00
2 changed files with 12 additions and 3 deletions
Showing only changes of commit 8f4cf09083 - Show all commits

View File

@ -2,11 +2,14 @@ import time
from source.strategy.strategy import SearchStats, PathFindingStrategy
from source.bububu.observer import Observer, Event
from source.classes.maze import Maze
class MazeSolver:
def __init__(self, maze, strategy: PathFindingStrategy):
def __init__(self, maze: Maze, strategy: PathFindingStrategy, observer: Observer):
self.maze = maze
self.strategy = strategy
self.observer = observer
def strategyName(self):
return self.strategy.name
@ -19,6 +22,12 @@ class MazeSolver:
path, visited_cells = self.strategy.findPath(self.maze)
finish_time = time.perf_counter()
self.observer.update(Event(
event="path_found",
player_position=self.maze.exit,
path=path
))
return SearchStats(
timeMs=finish_time - start_time,
visitedCells=visited_cells,

View File

@ -9,8 +9,8 @@ class PathFindingStrategy(ABC):
"""Интерфейс для семейства алгоритмов поиска пути от старта до выхода."""
@abstractmethod
def findPath(self, maze: Maze) -> tuple[list[Cell], int]:
"""Возвращающим список клеток пути (от старта до выхода включительно) или пустой список, если пути нет и количество посещённых клеток."""
def findPath(self, maze: Maze) -> tuple[list[tuple[int, int]], int]:
"""Возвращающим список координат клеток пути (от старта до выхода включительно) или пустой список, если пути нет и количество посещённых клеток."""
pass
@property
@abstractmethod