0412zc 发表于 2022-4-15 11:55:39

井字棋,怎样判断哪些位置已经被选过?

求问,如图,如果井字棋棋盘中有数字,二维数组 3 x 3, 让用户输入数字去选择下棋位置,被下过棋的位置用X或O代替。
怎样去判断棋盘上的位置已经被占用?

我试着用 case 1:if == 1,board = 'X'; 不过这样很麻烦,需要写9个case, 还有什么其他的方法吗? 谢谢。

andy大宝 发表于 2022-4-15 13:17:42

发源代码

风车呼呼呼 发表于 2022-4-15 13:32:20

再用一个二维数组去表示格点是否有棋子

AnisHan 发表于 2022-4-15 14:41:14

本帖最后由 AnisHan 于 2022-4-15 14:49 编辑

如果是窗口应用可以使用子窗口,如果是C可以用结构体,如果是C++可以定义类或者使用pair<>,如果是Java可以定义类,Pair<>

定义结构体或类就直接定义一个棋子可以表示有没有元素,是谁的棋
使用pair就是两个元素,用一个元素表示有没有棋子,另一个元素表示谁的棋子
或者使用纯int,用按位或 按位与 设置某个位,表示有没有棋,设置某位是谁的棋子
比如第4位表示下棋 数据& 0b0111 表示关闭第四位位 变成0 。数据 | 0b1000 打开第四位变成1,使用 (数据 & 1000)>> 3表示取出第四位数字

或者你不用0 1表示是谁的棋子,你用 1 2 表示,二维数组全部初始化为0 ,每次输入的时候判断一下是否为0,反正这很简单怎么弄都可以


关于后面检查更简单,一共就9个元素你不用设计什么算法,输入位置, x, y if (array != xxx),xxx是”标记“你最好用常量把所有的”标记“类似的都用常量,这叫magic number,以后改程序也方便
页: [1]
查看完整版本: 井字棋,怎样判断哪些位置已经被选过?