X-Git-Url: http://git.scottworley.com/slidingtile/blobdiff_plain/b18667f24728cb960b0c60fa55824062582278bf..cada47bfe401f2084c4248df10cdf0488bc8750a:/sliding_tile_lib.cc diff --git a/sliding_tile_lib.cc b/sliding_tile_lib.cc index 3b7806b..5037c8e 100644 --- a/sliding_tile_lib.cc +++ b/sliding_tile_lib.cc @@ -1,6 +1,8 @@ #include "sliding_tile_lib.h" #include +#include +#include signed char adjacent[BOARD_SIZE][5] = { 1, 4, -1, -1, -1, @@ -21,7 +23,7 @@ signed char adjacent[BOARD_SIZE][5] = { 11, 14, -1, -1, -1, }; -bool Board::is_valid() { +bool Board::is_valid() const { bool seen[BOARD_SIZE]; for (int i = 0; i < BOARD_SIZE; i++) { seen[i] = false; @@ -63,3 +65,22 @@ 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) { + return i; + } + } + throw std::runtime_error("Board with no hole"); +}