井字棋
这个判断胜利的函数在横排或者竖排连成一线时无法判断胜利,请问哪里出了问题以下为完整代码
#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;
} 问题出在判断胜利的函数中。在第一个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]