Eat.随 发表于 2023-11-9 10:06:07

井字棋

这个判断胜利的函数在横排或者竖排连成一线时无法判断胜利,请问哪里出了问题
以下为完整代码
#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:06:53

问题出在判断胜利的函数中。在第一个for循环中,判断条件应该是arr[ i] == 'X',而不是arr[ i] == 'x'。同样,在第二个for循环中,判断条件应该是arr == 'O',而不是arr == 'X'。由于大小写敏感,这两处错误导致无法正确判断胜利。

正确的判断胜利的函数代码如下:

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 == 'O' && arr == 'O' && arr == 'O')
      {
            return true;
      }
      else
      {
            break;
      }
    }
    return false;
}


这样修改后,就能正确判断胜利了。
页: [1]
查看完整版本: 井字棋