gpt4 book ai didi

Java 比较数组中的元素

转载 作者:行者123 更新时间:2023-12-02 08:06:34 28 4
gpt4 key购买 nike

我正在用 Java 创建一个基于文本的圈和十字游戏,并希望确定获胜情况。我为板使用了一个数组,例如 String [] board :-

[0][1][2]

[3][4][5]

[6][7][8]

我有一个完整的可能性列表,用于检查 if 语句中连续 3 个值是否相同。

这是我所拥有的一个示例:

if ((board [0] != "" && board [0] == board [1] && board [1] == board [2])) {
return true
}

有没有一种方法可以用更少的代码完成同样的事情?

谢谢

最佳答案

您的想法可以通过以下方式实现:

  • 如果您确实要存储字符串,请使用 .equals() 而不是 ==,或者
  • 存储字符而不是字符串,在这种情况下==是安全的。

现在,如果您真的在制作圈和十字游戏,您有 8 种不同的获胜条件,如果您改进当前的编码风格,这些条件将具有以下形式(这里我假设是字符,而不是字符串):

winner = 
(b[0] != ' ' && b[0] == b[1] && b[1] == b[2]) ||
(b[3] != ' ' && b[3] == b[4] && b[4] == b[5]) ||
...
(b[0] != ' ' && b[0] == b[4] && b[4] == b[8]);

还有其他方法可以做到这一点;我确信在 google 上搜索 tic-tac-toe 或 naughts and crosses 实现会向您展示不少内容。

如果您想尝试一下,有一种众所周知的技术,可以用 2 的幂“标记”每个单元格。然后,通过将分数相加(即查看玩家的位 vector )并对八个获胜条件进行二进制 AND 运算,您可以一次性确定获胜位置。

这是一个井字棋游戏的注释 block ,说明了该技术。 (您没有要求提供实际的代码,所以我从答案中扣除了代码):

/*
* To determine a win condition, each square is "tagged"
* from left to right, top to bottom, with successive
* powers of 2. Each cell thus represents an individual
* bit in a 9-bit string, and a player's squares at any
* given time can be represented as a unique 9-bit value.
* A winner can thus be easily determined by checking
* whether the player's current 9 bits have covered any
* of the eight "three-in-a-row" combinations.
*
* 273 84
* \ /
* 1 | 2 | 4 = 7
* -----+-----+-----
* 8 | 16 | 32 = 56
* -----+-----+-----
* 64 | 128 | 256 = 448
* =================
* 73 146 292
*
*/
var wins = [7, 56, 448, 73, 146, 292, 273, 84];

这是 JavaScript。对于 Java,请使用

private static final int[] WINS = new int[]{7, 56, 448, 73, 146, 292, 273, 84};

如果这里的二进制逻辑方法不是您想要的,我们深表歉意;我认为这将是一个展示它的好地方,以防其他人登陆此页面。

关于Java 比较数组中的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8072645/

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