当前位置: 首页 > article >正文

【小游戏篇】三子棋游戏

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

1.game.h

#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

#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

#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';
}


http://www.kler.cn/a/516926.html

相关文章:

  • 【0x0012】HCI_Delete_Stored_Link_Key命令详解
  • 【贪心算法】洛谷P1090 合并果子 / [USACO06NOV] Fence Repair G
  • IO进程 寒假作业
  • 设计模式的艺术-享元模式
  • leetcode_链表 21.合并两个有序链表
  • 前端开发中的模拟后端与MVVM架构实践[特殊字符][特殊字符][特殊字符]
  • Ubuntu18.04 搭建DHCP服务器
  • 08.七种排序算法实现(C语言)
  • Kafka中bin目录下面kafka-run-class.sh脚本中的JAVA_HOME
  • 浅谈APP之历史股票通过echarts绘图
  • 回归预测 | MATLAB基于TCN-BiGRU时间卷积神经网络结合双向门控循环单元多输入单输出回归预测
  • Jenkins pipline怎么设置定时跑脚本
  • js封装vue组件
  • C# OpenCV机器视觉:卡尔曼滤波
  • qt QNetworkRequest详解
  • 【springboot集成knife4j】
  • c++常见设计模式之装饰器模式
  • GPS信号生成:C/A码序列生成【MATLAB实现】
  • 基于单片机的水果保鲜仓库设计
  • OpenCV:高通滤波之索贝尔、沙尔和拉普拉斯
  • Day 16 卡玛笔记
  • opengrok_windows_多工程环境搭建
  • 小哆啦的编程冒险:罗马数字转整数
  • Golang笔记——静态强类型、编译型、并发型语言
  • Android OpenGL(六) 纹理
  • doris:Routine Load