鱼C论坛

 找回密码
 立即注册
查看: 477|回复: 1

[已解决]井字棋

[复制链接]
发表于 2023-11-9 10:22:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
这个判断胜利的函数在横排或者竖排连成一线时无法判断胜利,请问哪里出了问题(修改大小写之后还是不行,感觉可能是return false出了问题
以下为完整代码
#include <stdio.h>
#include <string.h>
#include <stdbool.h>
#include <stdlib.h>
#include <time.h>

void printArray(char arr[3][3])
{
    int i,j;
    for (i=0; i<3; i++)
    {
        for (j=0; j<3; j++)
        {
            printf("%c ", arr[i][j]);
        }
        printf("\n");
    }
}

bool winArrays(char arr[3][3]) 
{
    for (int i = 0; i < 3; i++) 
    {
        if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
        {
            return true;
        }
        else 
        {
            break;
        }
    }
    for (int j = 0; j < 3; j++) 
    {
        if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
        {
            return true;
        }
        else
        {
            break;
        }
    }
    return false;
    
}

void calculateRowAndCol(int x, int* row, int* col) 
{
    *row = 2 - ((x-1) / 3);
    *col = (x-1) % 3;
}


int main()
{
    char board_now[3][3] = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
    int i,x,y,row,col;
    for (i=0;i<9;i++)
    {
        for (i=0;i<5;i++)
        {
            printArray(board_now);
            printf("human input:");
            scanf("%i",&x);
            calculateRowAndCol(x, &row, &col);
            if (board_now[row][col] == '.')
            {
                board_now[row][col] = 'X';
                printf("\033[2J\033[H");
                break;
            }
            else 
            {
                printf("\033[2J\033[H");
                printf("you have done this.please input again.\n");
                i = i-1;
            }   
        }
        if (winArrays(board_now))
        {
            printf("human win.\n");
            break;
        }
        for (i=0;i<4;i++)
        {
            srand(time(NULL));
            y = rand()%(9+1);
            calculateRowAndCol(y, &row, &col);
            if (board_now[row][col] == '.')
            {
                board_now[row][col] = 'O';
                printf("\033[2J\033[H");
                break;
            }
            else 
            {
                i = i-1;
            }
        }  
    }     
}
以下为与判断胜利有关的代码
bool winArrays(char arr[3][3]) 
{
    for (int i = 0; i < 3; i++) 
    {
        if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
        {
            return true;
        }
        else 
        {
            break;
        }
    }
    for (int j = 0; j < 3; j++) 
    {
        if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
        {
            return true;
        }
        else
        {
            break;
        }
    }
    return false;
    
}



        if (winArrays(board_now))
        {
            printf("human win.\n");
            break;
        }
最佳答案
2023-11-9 10:23:27
问题出在判断胜利的函数 winArrays 中。在判断横排连成一线时,使用了一个 else 语句和 break 语句来处理不满足胜利条件的情况。然而,这样的处理方式是错误的,因为只要有一行不满足胜利条件,就不应该立即退出循环,而是应该继续检查下一行。同样的错误也出现在判断竖排连成一线的部分。

为了解决这个问题,我们需要删除 else 语句和 break 语句,以便在检查完所有行或列后才返回 false 。

修改后的代码如下:
bool winArrays(char arr[3][3]) 
{
    for (int i = 0; i < 3; i++) 
    {
        if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
        {
            return true;
        }
    }
    for (int j = 0; j < 3; j++) 
    {
        if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
        {
            return true;
        }
    }
    return false;
}

这样修改后,函数将正确判断是否胜利。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-9 10:23:27 | 显示全部楼层    本楼为最佳答案   
问题出在判断胜利的函数 winArrays 中。在判断横排连成一线时,使用了一个 else 语句和 break 语句来处理不满足胜利条件的情况。然而,这样的处理方式是错误的,因为只要有一行不满足胜利条件,就不应该立即退出循环,而是应该继续检查下一行。同样的错误也出现在判断竖排连成一线的部分。

为了解决这个问题,我们需要删除 else 语句和 break 语句,以便在检查完所有行或列后才返回 false 。

修改后的代码如下:
bool winArrays(char arr[3][3]) 
{
    for (int i = 0; i < 3; i++) 
    {
        if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
        {
            return true;
        }
    }
    for (int j = 0; j < 3; j++) 
    {
        if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
        {
            return true;
        }
    }
    return false;
}

这样修改后,函数将正确判断是否胜利。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-10-5 11:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表