如果可能的话,我怎样才能缩短这个?
if(moves[1] == moves[4] && moves[4] == moves[7]) { return 1;}
else if(moves[1] == moves[2] && moves[2] == moves[3]) { return 1;}
else if(moves[4] == moves[5] && moves[5] == moves[6]) { return 1;}
else if(moves[7] == moves[8] && moves[8] == moves[9]) { return 1;}
else if(moves[1] == moves[5] && moves[5] == moves[9]) { return 1;}
else if(moves[3] == moves[5] && moves[5] == moves[7]) { return 1;}
else if(moves[2] == moves[5] && moves[5] == moves[8]) { return 1;}
else if(moves[3] == moves[6] && moves[6] == moves[9]) { return 1;}
else if (moves[1] != '1' && moves[2] != '2' && moves[3] != '3' && moves[4] != '4' && moves[5] != '5' && moves[6] != '6' && moves[7] != '7' && moves[8] != '8' && moves[9] != '9') {
return 2;}
在值 move 中存储了一个 X 或 0 进行比较以获得游戏的获胜者我需要尽可能缩短它,
由于数字的随机组合,我想不出任何其他方式来做到这一点
上面的代码是一个名为 CheckWinner 的函数,它传递用户选择的输入,其中包含已填充的位置数组
代码检查 move[position] 与获胜移动的所有其他组合,如果检测到获胜移动,则返回 1。
最后一段代码检查网格上的所有空格,如果没有空格,则返回 2 以调用绘图。
希望这可以帮助