数组--三子棋

数组–三子棋

我的妈呀,从我出生到现在我写过的最长代码。
我终于把它给捋下来了。

下面是分装开的

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,但是哈哈哈哈哈。加油呗。

发布了25 篇原创文章 · 获赞 5 · 访问量 3630

猜你喜欢

转载自blog.csdn.net/weixin_45271990/article/details/104416957
今日推荐