X-Git-Url: http://git.scottworley.com/slidingtile/blobdiff_plain/9c32325fbc48baf135d0d7840e99ded70cb738f5..310a7132ffc617b93969703de7f3bf1c5ea0fa30:/sliding_tile_lib.h?ds=sidebyside diff --git a/sliding_tile_lib.h b/sliding_tile_lib.h index c5d0a8b..772817e 100644 --- a/sliding_tile_lib.h +++ b/sliding_tile_lib.h @@ -2,7 +2,9 @@ #define _SLIDING_TILE_LIB_H #include +#include #include +#include const int BOARD_DIM = 4; const int BOARD_SIZE = BOARD_DIM * BOARD_DIM; @@ -18,10 +20,20 @@ struct Board { InvertedBoard invert() const; int distance(const Board& o) const; int distance(const InvertedBoard& invo) const; + bool operator==(const Board& o) const; + bool operator!=(const Board& o) const; + bool operator<(const Board& o) const; }; std::istream& operator>>(std::istream& is, Board& board); std::ostream& operator<<(std::ostream& os, const Board& board); -extern signed char adjacent[BOARD_SIZE][5]; +struct Step { + Board board; + std::shared_ptr prev; + std::vector successors(std::shared_ptr shared_this); + static signed char adjacent[BOARD_SIZE][5]; +}; +std::ostream& operator<<(std::ostream& os, const Step& step); + #endif /* _SLIDING_TILE_LIB_H */