From 4aff1fa43edd9c602023bc611944d95d2786c8b8 Mon Sep 17 00:00:00 2001 From: Patricia Aas Date: Tue, 5 Oct 2021 15:33:03 +0200 Subject: [PATCH] Add suggested solution --- exercises/25/pacman_ai/solution/PacManAI.cpp | 33 ++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 exercises/25/pacman_ai/solution/PacManAI.cpp diff --git a/exercises/25/pacman_ai/solution/PacManAI.cpp b/exercises/25/pacman_ai/solution/PacManAI.cpp new file mode 100644 index 0000000..4a4cccf --- /dev/null +++ b/exercises/25/pacman_ai/solution/PacManAI.cpp @@ -0,0 +1,33 @@ +GridPosition PacManAI::pelletClosestToPacman(GridPosition pacmanGridPosition, + std::vector & pellets) { + + auto pelletSort = [&pacmanGridPosition](GridPosition pelletA, GridPosition pelletB) { + double distanceA = positionDistance(pacmanGridPosition, pelletA); + double distanceB = positionDistance(pacmanGridPosition, pelletB); + return distanceA < distanceB; + }; + std::sort(pellets.begin(), pellets.end(), pelletSort); + return pellets[0]; +} + +bool PacManAI::isValidMove(const Move & move) { + const bool isOpposite = (move.direction == oppositeDirection(direction)); + if (isOpposite) { + return false; + } + + const bool canWalk = isWalkableForPacMan(move.position); + if (!canWalk) { + return false; + } + return true; +} + +Direction PacManAI::optimalDirection(const std::array & moves) { + const auto optimalMove = std::min_element(moves.begin(), moves.end(), [](const auto & a, const auto & b) { + return a.distanceToTarget < b.distanceToTarget; + }); + + const auto & move = *optimalMove; + return move.direction; +}