forked from ibenes/freecell
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsearch-interface.cc
89 lines (68 loc) · 2 KB
/
search-interface.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#include "search-interface.h"
#include "game.h"
#include <cassert>
#include <algorithm>
unsigned long long SearchState::nbExpanded() {
return SearchState::nb_expanded;
}
bool operator<(const SearchState &a, const SearchState &b) {
return a.state_ < b.state_;
}
SearchState SearchAction::execute(const SearchState& state) const {
SearchState new_state(state);
bool succeeded = new_state.execute(from_, to_);
assert(succeeded);
return new_state;
}
bool SearchState::execute(Location from, Location to) {
auto from_ptr = ptrFromLoc(state_, from);
auto to_ptr = ptrFromLoc(state_, to);
if (!moveLegal(from_ptr, to_ptr))
return false;
move(const_cast<CardStorage *>(from_ptr), const_cast<CardStorage *>(to_ptr));
runSafeMoves_();
SearchState::nb_expanded++;
return true;
}
void SearchState::runSafeMoves_() {
std::vector<RawMove> safe_moves;
while ((safe_moves = safeHomeMoves(state_)), safe_moves.size() > 0) {
const CardStorage *from = safe_moves[0].first;
const CardStorage *to = safe_moves[0].second;
move(const_cast<CardStorage *>(from), const_cast<CardStorage *>(to));
}
}
bool SearchState::isFinal() const {
for (auto color : colors_list) {
if (!cardIsHome(state_, {color, king_value}))
return false;
}
return true;
}
unsigned long long SearchState::nb_expanded = 0;
std::vector<SearchAction> SearchState::actions() const {
auto raw_moves = availableMoves(
state_.non_homes.begin(),
state_.non_homes.end(),
state_.all_storage.begin(),
state_.all_storage.end()
);
std::vector<SearchAction> moves;
std::transform(
raw_moves.begin(),
raw_moves.end(),
std::back_inserter(moves),
[&](RawMove raw_move){
return SearchAction{locFromPtr(state_, raw_move.first), locFromPtr(state_, raw_move.second)};
}
);
return moves;
}
std::ostream& operator<< (std::ostream& os, const SearchState & state) {
os << state.state_;
return os;
}
std::ostream& operator<< (std::ostream& os, const SearchAction & action) {
os << action.from_ << " " << action.to_;
return os;
}