]> git.scottworley.com Git - slidingtile/blobdiff - sliding_tile_lib.h
Print paths
[slidingtile] / sliding_tile_lib.h
index c5d0a8bc66c99b7480d06a1c2b96811de9bbe6b6..c92676175647c664baf9d9b804ecdda54b72beb5 100644 (file)
@@ -2,7 +2,9 @@
 #define _SLIDING_TILE_LIB_H
 
 #include <istream>
+#include <memory>
 #include <ostream>
+#include <vector>
 
 const int BOARD_DIM = 4;
 const int BOARD_SIZE = BOARD_DIM * BOARD_DIM;
@@ -22,6 +24,13 @@ struct Board {
 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<Step> prev;
+  std::vector<Step*> successors(std::shared_ptr<Step> shared_this);
+  static signed char adjacent[BOARD_SIZE][5];
+};
+std::ostream& operator<<(std::ostream& os, const Step& step);
+
 
 #endif /* _SLIDING_TILE_LIB_H */