井字棋,怎样判断哪些位置已经被选过?
求问,如图,如果井字棋棋盘中有数字,二维数组 3 x 3, 让用户输入数字去选择下棋位置,被下过棋的位置用X或O代替。怎样去判断棋盘上的位置已经被占用?
我试着用 case 1:if == 1,board = 'X'; 不过这样很麻烦,需要写9个case, 还有什么其他的方法吗? 谢谢。 发源代码 再用一个二维数组去表示格点是否有棋子
本帖最后由 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]