gpt4 book ai didi

C++代码需要缩短

转载 作者:太空宇宙 更新时间:2023-11-04 15:22:07 24 4
gpt4 key购买 nike

如果可能的话我可以怎样缩短它?

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;}

在值 moves 中存储了一个 X 或 0,用于比较以获得游戏的获胜者我需要尽可能缩短它,

由于数字的随机组合,我想不出任何其他方式来做到这一点

上面的代码是一个名为 CheckWinner 的函数,它传递用户选择的输入以及已填充位置的数组

代码会根据获胜着法的所有其他组合检查着法 [位置],如果检测到获胜着法,则返回 1。

最后一段代码检查网格上的所有空间,如果没有剩余空间,则返回 2 以调用平局。

希望对你有帮助

最佳答案

这样的事情怎么样:

#include <stdio.h>

int winners[8][3] = { {1, 2, 3},
{4, 5, 6},
{7, 8, 9},
{1, 4, 7},
{2, 5, 8},
{7, 8, 9},
{1, 5, 9},
{3, 5, 7}};

int moves[10] = { 0,
1, 2, 0,
0, 2, 0,
0, 2, 1};

int main()
{
int i;
for (i=0;i<8;++i)
{
if (moves[winners[i][0]] == moves[winners[i][1]] &&
moves[winners[i][1]] == moves[winners[i][2]])
printf("Player %d wins!\n",moves[winners[i][0]]);
}
return 0;
}

数组 winners 描述了各种获胜组合,循环测试了每个组合。

关于C++代码需要缩短,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16408757/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com