数组–三子棋
我的妈呀,从我出生到现在我写过的最长代码。
我终于把它给捋下来了。
下面是分装开的
game.h
#ifndef __GAME_H__
#define __GAME_H__
#define ROW 3
#define COL 3
//函数的声明
void InitBoard(char board[ROW][COL], int row, int col);
void DispalyBoard(char board[ROW][COL], int row, int col);
void ComputerMove(char board[ROW][COL], int row, int col);
void PlayerMove(char board[ROW][COL], int row, int col);
char IsWin(char board[ROW][COL], int row, int col);
int IsFull(char board[ROW][COL], int row, int col);
////IsWin
//'x'——电脑赢了
//'0'——玩家赢了
//'p'——平局
//' ' ——继续
#endif //__GAME_H__
test.c
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include"game.h"//双引号引自己的头文件
void game()
{
char board[ROW][COL] = { 0 };
InitBoard(board, ROW, COL);
DispalyBoard(board, ROW, COL);
char ret = 0;
while (1)
{
ComputerMove(board, ROW, COL);
ret = IsWin(board, ROW, COL);
if (' ' != ret)
{
break;
}
DispalyBoard(board, ROW, COL);
PlayerMove(board, ROW, COL);
IsWin(board, ROW, COL);
if (' '!= ret)
{
break;
}
DispalyBoard(board, ROW, COL);
}
if ('X' == ret)
{
printf("电脑赢\n");
}
else if ('0' == ret)
{
printf("玩家赢\n");
}
else if ('p' == ret)
{
printf("平局\n");
}
DispalyBoard(board, ROW, COL);
}
void menu()
{
printf("*********************\n");
printf("****** 1.play *******\n");
printf("****** 0.exit *******\n");
printf("*********************\n");
}
int main()
{
int input = 0;
srand((unsigned int)time(NULL)); //头文件time.h stdlib.h
do{
menu();
printf("请选择:>");
scanf("%d", &input);
switch (input)
{
case 1:
game();
break;//如果没有break就会执行2
case 0:
printf("退出游戏\n");
break;
default:
printf("输入错误,请重新选择\n");
break;
}
printf("\n");
} while (input);
system("pause");
return 0;
}
game.c
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include "game.h"
//函数的实现
//数组初始化为空格
void InitBoard(char board[ROW][COL], int row, int col)
{
/*int i = 0;
int j = 0;
*/
//这个方法有点low 屏蔽掉了
//for (i = 0; i < row; i++)
//{
// for (j = 0; j < col; j++);
// {
// board[i][j] = ' ';
// }
//}
//memset(void*dest,int c ,size_t count)
//size_t count 初始化多少字节
//void*dest 起始地址
memset(&board[0][0], ' ', row*col*sizeof(board[0][0]));
}
//打印分界
void DispalyBoard(char board[ROW][COL], int row, int col)
{
int i = 0;
int j = 0;
for (i = 0; i < row;i++)
{
for (j = 0; j < col; j++)
{
printf(" %c ", board[i][j]);
if (j<col-1)
printf("|");
}
printf("\n");
if (i < row - 1)//控制分割行少一行
{
for (j = 0; j < row; j++)
{
printf("---");
if (j < col - 1)
printf("|");
}
printf("\n");
}
}
//比较低端一点的方法主要是代码不能动态实现
//for (i = 0; i < row; i++)
//{
// printf(" %c | %c | %c \n", board[i][0], board[i][1], board[i][2]);
// if (i<row-1)
// printf("---|---|---\n");
//}
}
void ComputerMove(char board[ROW][COL], int row, int col)
{
printf("电脑走:>\n");
while (1)
{
int x = rand() % row; //x的范围
int y = rand() % col; //y的
//判断坐标有没有被占用
if (' ' == board[x][y])
{
board[x][y] = 'X';
break;
}
}
}
void PlayerMove(char board[ROW][COL], int row, int col)
{
printf("玩家走:>\n");
while (1)
{
printf("请输入坐标\n");
int x = 0;
int y = 0;
scanf("%d%d", &x, &y);
if (x >= 1 && x <= row, y >= 1 && y <= col)//判断坐标是否合法 同时玩游戏的人并不是程序员所以会从1开始。
{
if (' ' == board[x - 1][y - 1])
{
board[x - 1][y - 1] = '0';
break;
}
else
{
printf("坐标被占用,请重新输入\n");
}
}
else
{
printf("坐标非法,请重新输入\n");
}
}
}
char IsWin(char board[ROW][COL], int row, int col)
{
//赢了
int i = 0;
for (i = 0; i < row; i++)
{
if (board[i][0] == board[i][1]
&& board[i][1] == board[i][2] && board != ' ')//并不是三个相等就一定有人赢了,如果三个都是空格。行
{
return board[i][0];
}
}
for (i = 0; i < col ; i++)
{
if (board[0][i] == board[1][i]
&& board[1][i] == board[2][i] && board != ' ')//列
{
return board[0][i];
}
}
if (board[0][0] == board[1][1]
&& board[1][1] == board[2][2] && board != ' ')//对角线
{
return board[1][1];
}
if (board[0][2] == board[1][1]
&& board[1][1] == board[2][0] && board != ' ')//对角线
{
return board[1][1];
}
// 判断平局
if (IsFull(board, ROW, COL))
{
return 'p';
}
return' ';
}
int IsFull(char board[ROW][COL], int row, int col)
{
int i = 0;
int j = 0;
for (i = 0; i < row; i++)
{
for (j = 0; j < col; j++)
{
if (board[i][j] == ' ')
return 0;
}
}
return 1;
}
复盘
没有感言,能弄下来,我都佩服我自己。虽然是跟着捋下来了的。过两天我要自己重新再搞一遍。
真的,我没夸张,这是我活到现在写过的最长代码。虽然很low,但是哈哈哈哈哈。加油呗。