Eat.随 发表于 2023-11-9 10:22:15

井字棋

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

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

bool winArrays(char arr)
{
    for (int i = 0; i < 3; i++)
    {
      if (arr[ i] == 'X' && arr[ i] == 'X' && arr[ i] == 'X')
      {
            return true;
      }
      else
      {
            break;
      }
    }
    for (int j = 0; j < 3; j++)
    {
      if (arr == 'X' && arr == 'X' && arr == '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 = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
    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 == '.')
            {
                board_now = '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 == '.')
            {
                board_now = 'O';
                printf("\033[2J\033[H");
                break;
            }
            else
            {
                i = i-1;
            }
      }
    }   
}
以下为与判断胜利有关的代码
bool winArrays(char arr)
{
    for (int i = 0; i < 3; i++)
    {
      if (arr[ i] == 'X' && arr[ i] == 'X' && arr[ i] == 'X')
      {
            return true;
      }
      else
      {
            break;
      }
    }
    for (int j = 0; j < 3; j++)
    {
      if (arr == 'X' && arr == 'X' && arr == 'X')
      {
            return true;
      }
      else
      {
            break;
      }
    }
    return false;
   
}



      if (winArrays(board_now))
      {
            printf("human win.\n");
            break;
      }

isdkz 发表于 2023-11-9 10:23:27

问题出在判断胜利的函数 winArrays 中。在判断横排连成一线时,使用了一个 else 语句和 break 语句来处理不满足胜利条件的情况。然而,这样的处理方式是错误的,因为只要有一行不满足胜利条件,就不应该立即退出循环,而是应该继续检查下一行。同样的错误也出现在判断竖排连成一线的部分。

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

修改后的代码如下:

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


这样修改后,函数将正确判断是否胜利。
页: [1]
查看完整版本: 井字棋