当我仅将 minmax 应用于我的 connect4 游戏时,它会得到正确的结果,直到深度 7 并且当我应用修剪以增加深度时,它会得到错误的结果,我需要帮助来知道我的逻辑或实现有什么问题?
private int score()
{
int winner = check_Winner(); // return 1 if player win or 2 when pc win or 0
if (winner == 1) return 10;
else if (winner == 2) return -10;
else return 0;
}
public int MinMax(int player_num, int depth, int alpha, int beta)
{
List<pair> possiple_moves = new List<pair>();
get_possible_moves( possiple_moves);
//================================================
int score_so_far = score();
if (possiple_moves.Count == 0 || score_so_far != 0 || depth == 10)// terminal case
return score_so_far;
//================================================
if (player_num == 1)// maxmize
{
int max_score = int.MinValue, temp = 0;
foreach (pair move in possiple_moves)
{
cells[move.x, move.y].player_num = 1;
temp = MinMax(2, depth + 1, alpha, beta);
if (temp > max_score)
{
max_score = temp;
pc_move = move;
}
cells[move.x, move.y].player_num = 0;
alpha = Math.Max(alpha, max_score);
if (beta <= alpha)
break;
}
return max_score;
}
//==========================
else
{
int min_score = int.MaxValue, tmp = 0;
foreach (pair move in possiple_moves)
{
cells[move.x, move.y].player_num = 2;
tmp = MinMax(1, depth + 1, alpha, beta);
if (tmp < min_score)
{
min_score = tmp;
pc_move = move;
}
cells[move.x, move.y].player_num = 0;
beta = Math.Min(beta, min_score);
if (beta <= alpha)
break;
}
return min_score;
}
}