【小游戏篇】三子棋游戏

硬控我一上午,小编还是太菜了,大家可以自行升级电脑难度,也可以升级游戏到五子棋

1.game.h

objectivec 复制代码
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<time.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 PlayerMove(char board[ROW][COL], int row, int col);
//电脑下棋
void ComputerMove(char board[ROW][COL], int row, int col);
//判断输赢
char IfWin(char board[ROW][COL], int row, int col);
int IfFull(char board[ROW][COL], int row, int col);

2.test.c

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include "game.h"
void menu()
	{
		printf("****************************\n");
		printf("****** 1.play 0.exist ******\n");
		printf("****************************\n");
	}
void game()
{
	char ret='C';
	char board[ROW][COL] = { 0 };
	//初始化棋盘的函数
	InitBoard(board,ROW,COL);
	DispalyBoard(board,ROW,COL);
	while (1)
	{
		PlayerMove(board,ROW,COL);
		ret=IfWin(board,ROW,COL);
		if (ret != 'C')
	      {
		 	break;
		  }
		DispalyBoard(board,ROW,COL);
		ComputerMove(board,ROW,COL);
		ret=IfWin(board,ROW,COL);
		if (ret != 'C')
		{
			break;
		}
		DispalyBoard(board,ROW,COL); 

	
	
	}

if (ret == '*')
	{
		printf("玩家赢\n");
	}		
	if (ret == '#')
	{
		printf("电脑赢\n");
	}
	if (ret == 'Q')
	{
		printf("平局\n");
	}
	

}

int main()
{
	int input = 0;
do
	{
	menu();//菜单
	printf("请选择:>");
	scanf("%d", &input);
	switch (input)
	{
	case 1:
		printf("三子棋\n");
		game();
		break;
	case 0:
		printf("退出游戏\n");
		break;
	default:
		printf("选择错误\n");
		break;
	}
} while (input);
return 0;

}

3.game.c

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include "game.h"
int IfFull(char board[ROW][COL],int row,int col)
{
	for (int i = 0;i < row;i++)
	{
		for (int j = 0;j < col;j++)
		{
			if (board[i][j] == ' ')
			{
				return 0;
			}
		}
	}
	return 1;
}
void InitBoard(char board[ROW][COL], int row, int col)
{

	for (int i = 0;i < row;i++)
	{
		for (int j = 0;j < col;j++)
		{
			board[i][j] = ' ';
		}
	}
}

void DispalyBoard(char board[ROW][COL], int row, int col)
{
	for (int i = 0;i < row;i++)
	{

		for (int j = 0;j < col;j++)
		{
			printf(" %c ", board[i][j]);
			if (j < col - 1)
				printf("|");
		}
		printf("\n");

		if (i < row - 1)
		{
			for (int j = 0;j < col;j++)
			{
				printf("---");
				if (j < col - 1)
					printf("|");

			}
			printf("\n");


		}
	}
}

void PlayerMove(char board[ROW][COL], int row, int col)
 {
	 int  x = 0, y = 0;
	 printf("玩家下棋:>\n");
	 while (1)
	 {
		
		 printf("请输入坐标:>");
		 scanf("%d %d", &x,&y);
		 if (x >= 1 && x <= row && y >= 1 && y <= col)
		 {
			 if (board[x - 1][y - 1] == ' ')
			 {
				 board[x - 1][y - 1] = '*';
				 break;
			 }
			 else
			 {
				 printf("坐标被占用,请选择其他位置\n");
			 }
		 }
		 else
		 {
			 printf("坐标非法,请重新输入\n");
		 }
	 }


}
 
void ComputerMove(char board[ROW][COL], int row, int col)
{
	srand((unsigned int)time(NULL));
	 printf("电脑下棋\n");
	 int x = 0, y = 0;
	 while(1)
	 {
		int  x = rand() % row;
		int  y = rand() % col;
		 if (board[x][y] == ' ')
		 {
			 board[x][y] = '#';
			 break;
		 }
	 }
 }

char IfWin(char board[ROW][COL], int row, int col)
{
	//行
	for (int i = 0;i < row;i++)
	{
		if (board[i][0] == board[i][1] && board[i][2] == board[i][1] && board[i][1] != ' ')
		{
			return board[i][0];
		}
	}
	//列
	
	for (int j = 0;j< col;j++)
	{
		if (board[0][j] == board[1][j] && board[1][j] == board[2][j] && board[1][j] !=' ')
		{
			return board[0][j];
		}
	}
	//对角线
	if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')
	{
		return board[0][0];
	}
	if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' ')
	{
		return board[1][1];
	}


	if (IfFull(board, row, col))
	{
		return 'Q';
	}
	return 'C';
}
相关推荐
How_doyou_do5 分钟前
浏览器本地存储Cookie, local/sessionStorage - Token结合Cookie实现登录管理
前端
烛阴13 分钟前
C# Dictionary 入门:用键值对告别低效遍历
前端·c#
灰灰勇闯IT41 分钟前
【探索实战】Kurator多集群统一应用分发实战:从环境搭建到业务落地全流程
算法
鱼在树上飞1 小时前
乘积最大子数组
算法
Sui_Network1 小时前
备受期待的 POP 射击游戏 XOCIETY 正式在 Epic Games Store 开启体验
人工智能·游戏·rpc·区块链·量子计算·graphql
H_z___1 小时前
Codeforces Round 1070 (Div. 2) A~D F
数据结构·算法
极速蜗牛1 小时前
告别部署焦虑!PinMe:前端开发者的极简部署神器
前端·javascript
自学小白菜1 小时前
每周刷题 - 第三周 - 双指针专题 - 02
python·算法·leetcode
杜子不疼.2 小时前
【LeetCode76_滑动窗口】最小覆盖子串问题
算法·哈希算法
ComputerInBook2 小时前
代数基本概念理解——特征向量和特征值
人工智能·算法·机器学习·线性变换·特征值·特征向量