c - c语言中的简单连接四个游戏
问题描述
在这个游戏中,你有一个 9 列 6 行的棋盘。开始时,第一列和最后一列填充了交替的玩家标记。计算机将随机选择哪个玩家(人类或计算机)首先移动。该玩家将他们的令牌放入棋盘中间的 7 列之一。(最左边和最右边的列已经满了)。然后下一个玩家做同样的事情。在任何时候,如果玩家丢下的令牌连续完成一组 5 个令牌(水平、垂直或对角),则该玩家赢得游戏。
我不能使用除 、 和 以外printf()
的scanf()
库putc()
函数getc()
。我对对角检查有一些问题,请帮助我这是我当前的代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define BOARD_ROWS 6
#define BOARD_COLS 9
void printBoard(char *board);
int takeTurn(char *board, int player, const char*);
int checkWin(char *board);
int checkfour(char* board , int,int,int,int);
int horizontalCheck(char *board);
int verticalCheck(char *board);
int diagonalCheck (char *board);
int main(int argc, char *argv[]){
const char *PIECES = "XO";
char board[BOARD_ROWS*BOARD_COLS];
for(int i =0; i< BOARD_ROWS*BOARD_COLS ; i ++){
board[i] = '.';
}
int turn, done=0;
for (turn=0; turn < BOARD_ROWS*BOARD_COLS && !done; turn++){
printBoard(board);
while(!takeTurn(board,turn %2, PIECES))
{
printBoard(board);
puts("**Column full!**\n");
}
done = checkWin(board);
}
printBoard(board);
if (turn == BOARD_ROWS*BOARD_COLS && !done)
{
puts("It's a tie!");
}
else{
turn--;
printf("player %d (%c) wins!\n", turn %2 + 1, PIECES[turn%2]);
}
return 0;
}
void printBoard(char *board){
int row,col;
puts("\n *****Connect tour*****\n");
for(row=0; row < BOARD_ROWS; row++){
for(col =0; col <BOARD_COLS;col++){
printf(" %c",board[BOARD_COLS * row+col]);
}
puts(" ");
//puts(".......");
}
puts(" ");
puts(" 1 2 3 4 5 6 7 8 9 \n");
}
int takeTurn(char*board, int player, const char *PIECES)
{
int row,col = 0;
printf("Player %d (%c): \nEnter number Coordinate:", player+1, PIECES[player]);
while(1){
if (1 != scanf("%d", &col) || col < 1 || col >9){
while(getchar() != '\n');
puts("number out of bounds! Try again.");
}
else{
break;
}
}
col--;
for(row = BOARD_ROWS-1; row>= 0; row--){
printf("here");
if(board[BOARD_COLS * row+col] == '.'){
board[BOARD_COLS * row+col] = PIECES[player];
return 1;
}
}
return 0;
}
int checkWin(char *board){
return(horizontalCheck(board)|| verticalCheck(board) || diagonalCheck(board));
}
int checkfour(char *board, int a, int b, int c , int d){
if (board[a] == board[b] && board[b]==board[c] && board[c]==board[d]&&board[a] != '.'){
return 1;
}
return 0;
}
int horizontalCheck(char *board){
int row,col,idx;
const int WIDTH = 1;
for (row=0; row<BOARD_ROWS; row++){
for(col = 0; col < BOARD_COLS-3; col++){
idx = BOARD_COLS * row+col;
if(checkfour(board, idx, idx + WIDTH, idx + WIDTH *2, idx + WIDTH*3)){
return 1;
}
}
}
return 0;
}
int verticalCheck(char*board){
int row,col,idx;
const int HEIGHT = 7;
for(row = 0; row< BOARD_ROWS-3; row++){
for(col = 0; col < BOARD_COLS;col++){
idx = BOARD_COLS*row+col;
if (checkfour(board, idx,idx+HEIGHT, idx+ HEIGHT*2, idx+ HEIGHT*3)){
return 1;
}
}
}
return 0;
}
int diagonalCheck(char *board){
int row,col,idx,Count = 0;
const int DIAG_RGT = 6, DIAG_LFT = 8;
for (row = 0; row < BOARD_ROWS-3; row++){
for(col = 0; col<BOARD_COLS;col++){
idx = BOARD_COLS*row+col;
if ((Count <=3 && checkfour(board, idx, idx+DIAG_LFT , idx+DIAG_LFT*2, idx + DIAG_LFT*3))||(
Count >=3&&checkfour(board,idx,idx+DIAG_RGT,idx+DIAG_RGT*2, idx+DIAG_RGT*3))){
return 1;
}
Count++;
}
Count = 0;
}
return 0;
}
解决方案
你的内心for
for(col = 0; col<BOARD_COLS;col++){
是直到BOARD_COLS
而不是BOARD_COLS-3
。在内部if
s 中,您需要检查一个方向 ( DIAG_RGT
) 或另一个方向 ( ) 是否存在这样的对角线DIAG_LFT
。这是有道理的,在第一个if
您将用于DIAG_RGT
计算索引,而在另一个if
您将使用DIAG_LFT
.
推荐阅读
- ssl - Python 的默认 SSL 证书上下文在代理后面时不能在请求方法中工作,否则工作正常
- mongodb - 如何更优雅地使用 Mongoose 进行重复验证?
- linux - 如何在 Linux 中查找特定文件的所有可用链接
- python - Jupyter 实验室虚拟环境
- firebase - Firebase 用户没有构造函数?
- reactjs - 为什么 Material-UI Button 的值没有传递给 onClick 事件处理程序?
- linux - 如何为锁定帐户设置特定的错误代码
- c# - 游戏统一开始后有没有办法将玩家分配给相机?
- c++ - 帧缓冲区大小更改但无法设置视口
- java - 在 Android Studio 中设置多个闹钟