手把手教你用C语言实现三子棋

美丽动人,英俊潇洒

本就是我们的优势

若在加上才华

就等于王炸


接下来手把手教你用C语言实现三子棋

第一步

建立一个项目 ——》在项目中建立三个文件:text.c game.c game.h

扫描二维码关注公众号,回复: 14126459 查看本文章

第二步

分析三子棋实现步骤 :

1.交互页面:输入1 —— 玩       输入0 —— 退出游戏

 2.建立棋盘

3. 下棋

 

5.判断结果

 第三步

代码实现:

test.c

#define  _CRT_SECURE_NO_WARNINGS 1
#include"game.h"

void menu()
{
	printf("**********************\n");
	printf("*** 1.play  0.exti ***\n");
	printf("**********************\n");
}

void Gobang()
{
	srand((unsigned)time(NULL));
	char tmp = 'C';
	char board[Line][Row] = { 0 };//棋盘
	//1.初始化棋盘
	initial(board, Line, Row);
	//2.打印棋盘
	print(board, Line, Row);
	while (1)
	{
		//3.下棋(玩家先下,电脑再下)
		//玩家下
		player(board, Line, Row);
		tmp = judge(board, Line, Row);
		if (tmp != 'C')
			break;
		print(board, Line, Row);//打印棋盘
		//电脑下
		computer(board, Line, Row);
		tmp = judge(board, Line, Row);
		if (tmp != 'C')
			break;
		print(board, Line, Row);//打印棋盘
		//4.判断输赢
	}
	if (tmp == '*')
		printf("玩家赢\n");
	else if (tmp == '#')
		printf("电脑赢\n");
	else
		printf("平局\n");
	print(board, Line, Row);//打印棋盘

}

int main()
{
	
	int input = 0;
	do
	{
		menu();
		printf("请输入你的选择 >> ");
		scanf("%d", &input);
		switch (input)
		{
		case 1:Gobang(); break;//开始游戏
		case 0:printf("退出游戏\n"); break;
		default:printf("请重新输入\n"); break;
		}

	} while (input!=0);
	
	system("pause");
}

 game.h

#include<windows.h>
#include<stdio.h>
#include<stdlib.h>
#include<time.h>

#define Line 5//行
#define Row 5//列

//初始化棋盘
void initial(char board[Line][Row], int line, int row);
//打印棋盘
void print(char board[Line][Row], int line, int row);
//玩家下棋
void player(char board[Line][Row], int line, int row);
//电脑下棋
void computer(char board[Line][Row], int line, int row);
//判断输赢
char judge(char board[Line][Row], int line, int row);

game.c

#define  _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
//将棋盘初始化为空
void initial(char board[Line][Row], int line, int row)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < line; i++)
	{
		for (j = 0; j < row; j++)
		{
			board[i][j] = ' ';
		}
	}
}

//打印棋盘
void print(char board[Line][Row], int line, int row)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < line; i++)
	{
		for (j = 0; j < row; j++)
		{
			printf(" %c ", board[i][j]);
			if (j < row - 1)
			{
				printf("|");
			}
		}
		printf("\n");

		for (j = 0; j < row; j++)
		{
			if (i < line - 1)
			{
				printf("---");
				if (j < row - 1)
				{
					printf("|");
				}
			}
		}
		printf("\n");
	}

}

//玩家下棋
void player(char board[Line][Row], int line, int row)
{
	int i = 0;
	int j = 0;
	while (1)
	{
		printf("请玩家下棋 >> ");
		scanf("%d%d", &i, &j);
		if (board[i-1][j-1] = ' ' && i-1 < line && j-1 < row && i - 1 >= 0 && j - 1 >= 0)
		{
			board[i-1][j-1] = '*';
			break;
		}
		else
		{
			printf("输入错误请重新输入\n");
		}
	}
}

//电脑下棋
void computer(char board[Line][Row], int line, int row)
{
	
	while (1)
	{
		int i = rand() % line;
	    int j = rand() % row;
		printf("请电脑下棋 >> \n");
		if (board[i][j] == ' ')
		{
			board[i][j] = '#';
			break;
		}
	}
}

//判断输赢
char judge(char board[Line][Row], int line, int row)
{
	int i = 0;
	int j = 0;
	int t = 0;
	//判断行低级版本
	//for (i = 0; i < line; i++)
	//{
	//	if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][0] != ' ')
	//	{
	//		return board[i][0];
	//	}
	//}

	//判断行高级版本
	for (i = 0; i < line; i++)
	{
		for (j = 0; j < row; j++)
		{
			if (j < row - 2 && board[i][j] != ' ' &&  board[i][j] == board[i][j + 1] && board[i][j + 1] == board[i][j + 2])
			{
				return board[i][j];
			}
		}
	}

	//判断列低级版本
	//for (i = 0; i < row; i++)
	//{
	//	if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[0][i] != ' ')
	//	{
	//		return board[0][i];
	//	}
	//}

	//判断列高级版本
	for (i = 0; i < row; i++)
	{
		for (j = 0; j < line; j++)
		{
			if (j < line - 2 && board[j][i] != ' ' &&  board[j][i] == board[j + 1][i] && board[j + 1][i] == board[j+ 2][i])
			{
				return board[j][i];
			}
		}
	}

	//判断对角线低级版本
	//if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[0][0] != ' ' || board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[0][2] != ' ')
	//{
	//	return board[1][1];
	//}

	//判断对角线高级版本
	//正对角线
	for (i = 0, j = 0; i < line, j < row; i++, j++)
	{
		if (i < line - 2 && j < row - 2 && board[i][j] != ' '&&board[i][j] == board[i + 1][j + 1] && board[i][j] == board[i + 2][j + 2])
		{
			return board[i][j];
		}
	}
	//反对角线
	for (i = 0; i < line; i++)
	{
		for (j = 0; j < row; j++)
		{
			if (j >= 2 && board[i][j] != ' ' && board[i][j] == board[i + 1][j - 1] && board[i][j] == board[i + 2][j - 2])
			{
				return board[i][j];
			}
		}
	}
	

	//平局
	for (i = 0; i < line; i++)
	{
		for (j = 0; j < row; j++)
		{
			if (board[i][j] == ' ')
			{
				t = 1;
			}
		}
	}
	if (t != 1)
	{
		return 'D';
	}

	return 'C';
}

猜你喜欢

转载自blog.csdn.net/m0_66488562/article/details/124633087