X-Git-Url: http://git.scottworley.com/slidingtile/blobdiff_plain/cea272cfec1cf181ca673cc9454517b6d91a4f97..9c32325fbc48baf135d0d7840e99ded70cb738f5:/sliding_tile_lib.cc diff --git a/sliding_tile_lib.cc b/sliding_tile_lib.cc index 5b2e798..aee8380 100644 --- a/sliding_tile_lib.cc +++ b/sliding_tile_lib.cc @@ -1,6 +1,8 @@ #include "sliding_tile_lib.h" +#include #include +#include #include signed char adjacent[BOARD_SIZE][5] = { @@ -65,6 +67,16 @@ std::istream& operator>>(std::istream& is, Board& board) { return is; } +std::ostream& operator<<(std::ostream& os, const Board& board) { + for (int i = 0; i < BOARD_SIZE; i++) { + if (i > 0) { + os << " "; + } + os << int(board.board[i]); + } + return os; +} + signed char Board::hole() const { for (int i = 0; i < BOARD_SIZE; i++) { if (board[i] == 0) { @@ -73,3 +85,24 @@ signed char Board::hole() const { } throw std::runtime_error("Board with no hole"); } + +InvertedBoard Board::invert() const { + InvertedBoard inv; + for (int i = 0; i < BOARD_SIZE; i++) { + inv.pos[board[i]] = i; + } + return inv; +} + +int Board::distance(const Board& o) const { + return distance(o.invert()); +} + +int Board::distance(const InvertedBoard& invo) const { + int dist = 0; + for (int i = 0; i < BOARD_SIZE; i++) { + dist += std::abs(i % BOARD_DIM - invo.pos[board[i]] % BOARD_DIM) + + std::abs(i / BOARD_DIM - invo.pos[board[i]] / BOARD_DIM); + } + return dist; +}