鱼C论坛

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

[已解决]井字棋

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

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

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

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

  6. void printArray(char arr[3][3])
  7. {
  8.     int i,j;
  9.     for (i=0; i<3; i++)
  10.     {
  11.         for (j=0; j<3; j++)
  12.         {
  13.             printf("%c ", arr[i][j]);
  14.         }
  15.         printf("\n");
  16.     }
  17. }

  18. bool winArrays(char arr[3][3])
  19. {
  20.     for (int i = 0; i < 3; i++)
  21.     {
  22.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  23.         {
  24.             return true;
  25.         }
  26.         else
  27.         {
  28.             break;
  29.         }
  30.     }
  31.     for (int j = 0; j < 3; j++)
  32.     {
  33.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  34.         {
  35.             return true;
  36.         }
  37.         else
  38.         {
  39.             break;
  40.         }
  41.     }
  42.     return false;
  43.    
  44. }

  45. void calculateRowAndCol(int x, int* row, int* col)
  46. {
  47.     *row = 2 - ((x-1) / 3);
  48.     *col = (x-1) % 3;
  49. }


  50. int main()
  51. {
  52.     char board_now[3][3] = {{'.','.','.'},{'.','.','.'},{'.','.','.'}};
  53.     int i,x,y,row,col;
  54.     for (i=0;i<9;i++)
  55.     {
  56.         for (i=0;i<5;i++)
  57.         {
  58.             printArray(board_now);
  59.             printf("human input:");
  60.             scanf("%i",&x);
  61.             calculateRowAndCol(x, &row, &col);
  62.             if (board_now[row][col] == '.')
  63.             {
  64.                 board_now[row][col] = 'X';
  65.                 printf("\033[2J\033[H");
  66.                 break;
  67.             }
  68.             else
  69.             {
  70.                 printf("\033[2J\033[H");
  71.                 printf("you have done this.please input again.\n");
  72.                 i = i-1;
  73.             }   
  74.         }
  75.         if (winArrays(board_now))
  76.         {
  77.             printf("human win.\n");
  78.             break;
  79.         }
  80.         for (i=0;i<4;i++)
  81.         {
  82.             srand(time(NULL));
  83.             y = rand()%(9+1);
  84.             calculateRowAndCol(y, &row, &col);
  85.             if (board_now[row][col] == '.')
  86.             {
  87.                 board_now[row][col] = 'O';
  88.                 printf("\033[2J\033[H");
  89.                 break;
  90.             }
  91.             else
  92.             {
  93.                 i = i-1;
  94.             }
  95.         }  
  96.     }     
  97. }
复制代码

以下为与判断胜利有关的代码
  1. bool winArrays(char arr[3][3])
  2. {
  3.     for (int i = 0; i < 3; i++)
  4.     {
  5.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  6.         {
  7.             return true;
  8.         }
  9.         else
  10.         {
  11.             break;
  12.         }
  13.     }
  14.     for (int j = 0; j < 3; j++)
  15.     {
  16.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  17.         {
  18.             return true;
  19.         }
  20.         else
  21.         {
  22.             break;
  23.         }
  24.     }
  25.     return false;
  26.    
  27. }



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

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

修改后的代码如下:

  1. bool winArrays(char arr[3][3])
  2. {
  3.     for (int i = 0; i < 3; i++)
  4.     {
  5.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  6.         {
  7.             return true;
  8.         }
  9.     }
  10.     for (int j = 0; j < 3; j++)
  11.     {
  12.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  13.         {
  14.             return true;
  15.         }
  16.     }
  17.     return false;
  18. }
复制代码


这样修改后,函数将正确判断是否胜利。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

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

修改后的代码如下:

  1. bool winArrays(char arr[3][3])
  2. {
  3.     for (int i = 0; i < 3; i++)
  4.     {
  5.         if (arr[ i][0] == 'X' && arr[ i][1] == 'X' && arr[ i][2] == 'X')
  6.         {
  7.             return true;
  8.         }
  9.     }
  10.     for (int j = 0; j < 3; j++)
  11.     {
  12.         if (arr[0][j] == 'X' && arr[1][j] == 'X' && arr[2][j] == 'X')
  13.         {
  14.             return true;
  15.         }
  16.     }
  17.     return false;
  18. }
复制代码


这样修改后,函数将正确判断是否胜利。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 00:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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