]> git.scottworley.com Git - slidingtile/blobdiff - sliding_tile_lib.h
successors is const
[slidingtile] / sliding_tile_lib.h
index 0bd3da32cade27ab812d2e3224e08f1476bd3b0b..1b56da4c80a7e4fbc18947abc4a6f193c0eb057c 100644 (file)
@@ -20,6 +20,9 @@ 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);
@@ -27,9 +30,10 @@ std::ostream& operator<<(std::ostream& os, const Board& board);
 struct Step {
   Board board;
   std::shared_ptr<Step> prev;
-  std::vector<Step*> successors(std::shared_ptr<Step> shared_this);
+  std::vector<Step*> successors(std::shared_ptr<Step> shared_this) const;
   static signed char adjacent[BOARD_SIZE][5];
 };
+std::ostream& operator<<(std::ostream& os, const Step& step);
 
 
 #endif /* _SLIDING_TILE_LIB_H */