首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >简单连接c中的四个游戏

简单连接c中的四个游戏
EN

Stack Overflow用户
提问于 2019-12-07 18:23:51
回答 1查看 427关注 0票数 0

在这个游戏中,你有一个9列,6行的棋盘。在开始时,第一列和最后一列使用交替的玩家令牌填充。计算机将随机选择哪个玩家(人类或计算机)先移动。玩家将他们的代币放入棋盘中间7栏中的一栏。(最左边和最右边的列已经满了)。然后下一个玩家也会做同样的事情。在任何时候,如果玩家丢下一个令牌,该令牌连续完成一组5个令牌(水平、垂直或对角),该玩家将赢得游戏。

我不能使用printf()scanf()putc()getc()以外的库函数。我的diagonalCheck有一些问题,请帮助我这是我当前的代码

代码语言:javascript
运行
复制
#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;
}
EN

回答 1

Stack Overflow用户

发布于 2019-12-07 18:51:50

你内心的for for(col = 0; col<BOARD_COLS;col++){一直到BOARD_COLS而不是BOARD_COLS-3。在内部if中,您需要检查是否有这样的对角线指向一个方向(DIAG_RGT)或另一个方向(DIAG_LFT)。在第一个if中,您将使用DIAG_RGT来计算索引,而在另一个if中,您将使用DIAG_LFT

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59225020

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档