|
@@ -75,11 +75,6 @@ bool Game::parseLine(const String& line) {
|
|
line == "************************Player 2 won!**********************") {
|
|
line == "************************Player 2 won!**********************") {
|
|
// stop the game if anybody wins - the server does not do that
|
|
// stop the game if anybody wins - the server does not do that
|
|
std::cerr << line << "\n";
|
|
std::cerr << line << "\n";
|
|
-
|
|
|
|
- //std::cerr << "Turns: " << turns << "\n";
|
|
|
|
- //std::cerr << "Moves: " << moves << "\n";
|
|
|
|
- //std::cerr << "Total selection time: " << selectionTime << "\n";
|
|
|
|
- //std::cerr << "Total move time: " << moveTime << "\n";
|
|
|
|
std::cerr << turns << "," << moves << "," << selectionTime << "," << moveTime << "\n";
|
|
std::cerr << turns << "," << moves << "," << selectionTime << "," << moveTime << "\n";
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
@@ -193,7 +188,7 @@ uint Game::move(const Vector& from, const Vector& to) {
|
|
direction = to - from;
|
|
direction = to - from;
|
|
// remember the old location to block moving to it again
|
|
// remember the old location to block moving to it again
|
|
lastLocations.add(from);
|
|
lastLocations.add(from);
|
|
- // actually from the stone
|
|
|
|
|
|
+ // actually move the stone
|
|
fields.setState(to, fields.getState(from));
|
|
fields.setState(to, fields.getState(from));
|
|
fields.setState(from, Fields::EMPTY);
|
|
fields.setState(from, Fields::EMPTY);
|
|
// get the enemy by inverting the goal state
|
|
// get the enemy by inverting the goal state
|
|
@@ -347,6 +342,7 @@ bool Game::isTakingPossible() const {
|
|
// check if any white neighbored stone can move to the found empty stone
|
|
// check if any white neighbored stone can move to the found empty stone
|
|
for(Vector& m : neighbours) {
|
|
for(Vector& m : neighbours) {
|
|
Vector from = to + m;
|
|
Vector from = to + m;
|
|
|
|
+ // prevent invalid moves
|
|
if(!isInRange(from) || !areNeighbors(from, to) || !fields.hasState(from, Fields::WHITE)) {
|
|
if(!isInRange(from) || !areNeighbors(from, to) || !fields.hasState(from, Fields::WHITE)) {
|
|
continue;
|
|
continue;
|
|
}
|
|
}
|
|
@@ -385,4 +381,4 @@ uint Game::getBestEnemyRank() const {
|
|
|
|
|
|
long int Game::getNanos() {
|
|
long int Game::getNanos() {
|
|
return std::chrono::high_resolution_clock::now().time_since_epoch().count();
|
|
return std::chrono::high_resolution_clock::now().time_since_epoch().count();
|
|
-}
|
|
|
|
|
|
+}
|