-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMinMaxNode.cpp
More file actions
45 lines (41 loc) · 848 Bytes
/
MinMaxNode.cpp
File metadata and controls
45 lines (41 loc) · 848 Bytes
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
#include "MinMaxNode.h"
#include <cmath>
#include <cstring>
#include <cstdlib>
MinMaxNode::MinMaxNode()
{
value = 0.0;
}
MinMaxNode::MinMaxNode(MinMaxNode* fa, Point op)
{
value = 0.0;
memcpy(A, fa->A, sizeof A);
memcpy(&dsu, &fa->dsu, sizeof dsu);
step = fa->step;
setPiece(op.x, op.y, moveColor());
}
double MinMaxNode::Evaluate(Color my)
{
double ret = 0;
for (int i = 0; i < 9; i++)
for (int j = 0; j < 9; j++)
if (A[i][j] == Color::SPACE)
{
bool f1 = isLegal(i, j, my), f2 = isLegal(i, j, my == Color::WHITE ? Color::BLACK : Color::WHITE);
if (f1 && !f2)
ret++;
if (!f1 && f2)
ret-=10;
}
return ret;
}
void MinMaxNode::debug()
{
std::cerr << "Debug:" << this << std::endl;
for (int i = 0; i < 9; i++)
{
for (int j = 0; j < 9; j++)
std::cerr << (int)A[i][j];
std::cerr << std::endl;
}
}