繁体   English   中英

黑白棋 - C 编程中的棋盘配置和移动合法性检查

[英]Reversi Game – Board Configuration and Move Legality Checking in C programming

在下面的程序中输入应该是这样的形式:U-为未占用,B-由黑色占用,W-由白色占用。 程序在初始化电路板后应要求用户配置,然后使用用户配置打印电路板。 然后它相应地打印 'W' 和 'B' 的可用移动。 最后一步是要求使用的棋步,如果它与之前打印的可用棋步匹配,则打印棋步有效的消息,然后使用有效棋步最后一次打印棋盘。 打印配置的电路板后,我在这里得到了一些奇怪的输出。 请在这里帮忙,谢谢。 这是一个示例输入和预期输出:

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
void boardInitialize(char board[26][26], int n);
void printBoard(char board[26][26], int n);
bool checkLegalMovesAvailable(char board[26][26], int N, char colour);
bool positionInBounds(int N, char row, char col);
void printMove(char board[26][26], int n);
bool checkLegalInDirection(char board[26][26],int N,char row,char col,char colour,int deltaRow,int deltaCol);
bool checkLegalInMove(char board[26][26], int N, char row, char col, char colour);

int main(void){
    int n;
    char board[26][26];
    printf("Enter the board dimension: ");
    scanf("%d",&n);
    boardInitialize(board,n);
    printBoard(board,n);
    if(checkLegalMovesAvailable(board,n,'W'))
        checkLegalMovesAvailable(board,n,'B');
    printMove(board,n);

    return (EXIT_SUCCESS);
}

//Function to initialize board
void boardInitialize(char board[26][26], int n){
    printf("  ");
    for(int i=0;i<n;i++){
        printf("%c",97+i);
    }
    printf("\n");
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            board[i][j]='U';
        }
    }
    board[(n/2)-1][(n/2)-1]='W';
    board[n/2][n/2]='W';
    board[(n/2)-1][n/2]='B';
    board[n/2][(n/2)-1]='B';
    for(int i=0;i<n;i++){
        printf("%c ",97+i);
        for(int j=0;j<n;j++){
            printf("%c",board[i][j]);
        }
        printf("\n");
    }
}

//Function to print board after configuration
void printBoard(char board[26][26], int n){
    printf("Enter board configuration:");
    printf("\n");
    char color,row,col;
    for(int i=0;(color!='!' && row!='!' && col!='!');i++){
        scanf(" %c%c%c",&color,&row,&col);
            board[row-'a'][col-'a']=color;
    }
    printf("  ");
    for(int i=0;i<n;i++){
        printf("%c",97+i);
    }
    printf("\n");
    for(int i=0;i<n;i++){
        printf("%c ",97+i);
        for(int j=0;j<n;j++){
            printf("%c",board[i][j]);
        }
        printf("\n");
    }   
}

//function to print available moves after configuration
bool checkLegalMovesAvailable(char board[26][26], int N, char colour){
    int done=1;
    printf("Available moves for %c:\n",colour);
    for(int i=0;i<N;i++){
        for(int j=0;j<N;j++){
            if(board[i][j]==colour){
                for(int deltaRow=-1;deltaRow<=1;deltaRow++){
                    for(int deltaCol=-1;deltaCol<=1 && done!=0;deltaCol++){
                        if((positionInBounds(N,('a'+deltaRow), ('a'+deltaCol))) && (checkLegalInDirection(board,N,('a'+deltaRow),('a'+deltaCol),colour,deltaRow,deltaCol)))
                            done++;
                    }
                }   
            }
        }
    }
    return true; 
}

//function to check if any move is legal in a specific direction
bool checkLegalInDirection(char board[26][26],int N,char row,char col,char colour,int deltaRow,int deltaCol){
    int r=row-'a', c=col-'a',count=2;
    if((board[r+deltaRow][c+deltaCol]!=colour) && (board[r+deltaRow][c+deltaCol]!='U')){
        for(int i=0;i<N;i++){
                if((board[r+(count*deltaRow)][c+(count*deltaCol)]!=colour) &&(board[r+(count*deltaRow)][c+(count*deltaCol)]!='U'))
                    count++;
                else
                    count--;
                printf("%c%c\n",(row+(count*deltaRow)),(col+(count*deltaCol)));
            }
            return true;
    }
    else
        if(board[r+deltaRow][c+deltaCol]==colour || board[r+deltaRow][c+deltaCol]=='U')
        return false;
    }

//function to check if the specified row,col lies within the board dimensions
bool positionInBounds(int N, char row, char col){
    int p=row-'a',q=col-'a';
    if(p>=0 && p<=N){
        if(q>=0 && q<=N)
            return true;
        else
            return false;
    }
    else
        return false;
}

//function to print board after a legal move 
void printMove(char board[26][26], int n){
    char color,row,col;
    printf("Enter a move:\n");
    scanf(" %c%c%c",&color,&row,&col);
    board[row-'a'][col-'a']=color;
    if(checkLegalInMove(board,n,row,col,color)){
        printf("  ");
        for(int i=0;i<n;i++){
            printf("%c",97+i);
        }
        printf("\n");
        for(int i=0;i<n;i++){
            printf("%c ",97+i);
            for(int j=0;j<n;j++){
                printf("%c",board[i][j]);
            }
            printf("\n");
        }
    }
}

//function to check if any specific move is legal
bool checkLegalInMove(char board[26][26], int N, char row, char col, char colour){
    int r=row-'a',c=col-'a';
    for(int deltaRow=-1;deltaRow<=1;deltaRow++){
        for(int deltaCol=-1;deltaCol<=1;deltaCol++){
            if((positionInBounds(N,row,col)) && (checkLegalInDirection(board,N,('a'+r),('a'+c),colour,deltaRow,deltaCol))){
                printf("Valid move.\n");
                return true;
            }
            else{
                printf("Invalid move.\n");
                return true;
            }
        }
    }
}

这里有很多问题。 以下是一些:

(1) 在您的scanf调用之一中,您忘记获取要存储结果的变量的地址。 gcc对此发出警告:

scanf(" %c%c%c",color,row,col);

尝试将其更改为:

scanf(" %c%c%c",&color,&row,&col);

(2) 在checkLegalInDirection ,在打印移动时,您正在减去“a”,这当然是错误的,因为您尝试打印的是字符,而不是偏移量。 所以改变:

printf("%c%c\n",(row+(count*deltaRow)-'a'),(col+(count*deltaCol)-'a'));

到:

printf("%c%c\n",(row+(count*deltaRow)),(col+(count*deltaCol)));

(3) checkLegalMovesAvailable应该返回一个bool ,但函数中的任何地方都没有return语句。 这意味着如果调用者尝试检查返回值,它将获取一些随机值。 向函数添加一个return语句,并让它返回一个bool值。

我不相信这些是唯一的问题,但我真的认为你需要花一些时间来解决这个问题,所以我会让你从这个开始。 希望这会有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM