井字棋小游戏c语言简单编码,C语言实现简易井字棋游戏
井子棋承载了每个人孩童时的美好时光,小到书本、纸张,大到课桌、墙壁,总能找到井字棋盘的痕迹。今天我们就来实际操作一番,用C语言完成一个简单的井字棋游戏,让我们一起重温美好。
棋盘如下:
**功能描述:**棋盘共分为九个格子,一方执“O”为棋,一方执“X”为棋,双方依次选择格子。己方棋子率先连成三子的获胜,若棋盘占满仍未分胜负,则打成平局。
具体功能实现:
1.在页面选择玩家vs玩家,或玩家vs电脑
2.玩家下棋时,输入对应格子的坐标
3.电脑下棋时,使用随机值选择坐标
4.每下一步,棋盘更新一次
5.当率先有三颗相同棋子横向或纵向或斜向连成线,则为赢,游戏结束
6.若棋盘下满后,仍未有赢家则为平局,游戏结束
7.游戏结束后返回菜单,选择继续游戏或退出
具体各函数构建:
1、菜单函数:当玩家打开程序,首先弹出一个菜单,供玩家选择,直接使用printf打印即可。
void Menu() {
printf("********欢迎来到三子棋游戏室********\n");
printf("************************************\n");
printf("***********1、开始游戏**************\n");
printf("***********2、退出游戏**************\n");
printf("************************************\n");
}
2、清空棋盘:用二维数组表示棋盘时,先创建好char 类型的二维数组,此时需要将数组中的各元素全变为“ ”(空格),已便于下一步打印棋盘。
void InitBoard(char arr[][COL], int row, int col) {
int i, j;
for (i = 0; i < row; i++)
for (j = 0; j < col; j++) {
arr[i][j] = ' ';
}
}
3、打印棋盘:当二维数组清空后,直接将二维数组个元素并配合“----------”“|”利用循环逐一打印,实现棋盘的打印
void ShowBoard(char arr[][COL], int row, int col) {
int i;
printf(" | 1 | 2 | 3 |\n");
for (i = 0; i < row; i++) {
printf("----------------\n");
printf(" %d | %c | %c | %c |\n", i+1, arr[0][i], arr[1][i], arr[2][i]);
}
}
4、玩家落子:打印棋盘后,该玩家输入相应的坐标落子,判断玩家选择的位置无棋子赋值即可
void WhiteJudge(char arr[][COL], int row, int col) {
printf("请选择你要下棋子的坐标");
int x = 0, y = 0;
reselect:
scanf("%d%d", &x, &y);
if (arr[x-1][y-1] == ' ')
arr[x-1][y-1] = WHITEBOARD;
else {
printf("你选择的格子已有棋子,请重选:");
goto reselect;
}
}
5、电脑落子:玩家落子结束后,电脑通过设定范围内的随机值选择坐标,同样判断该位置无棋子时,方可赋值
void BlackJudge(char arr[][COL],int row, int col) {
while (1) {
int h = rand() % row;
int l = rand() % col;
if (arr[h][l] == ' ') {
printf("电脑落子:%d %d\n", h + 1, l + 1);
arr[h][l] = BLACKBOARD;
break;
}
}
printf("\n");
}
6、赢家判断:在横向,纵向,斜向三方向下,判断是否有三颗相同棋子连成一条线,若有则执该棋者为赢家
char WinJudge(char arr[][COL], int row, int col) {
int i, j=0;
for (i = 0; i < 3; i++) {
if (arr[i][j] != ' '&&arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2])
return arr[i][0];
}
for (i = 0; i < 3; i++) {
if (arr[0][i] != ' '&&arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i])
return arr[0][i];
}
if (arr[0][0] != ' '&&arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2]) {
return arr[0][0];
}
if (arr[2][0] != ' '&&arr[2][0] == arr[1][1] && arr[1][1] == arr[0][2]) {
return arr[2][0];
}
for (i = 0; i < row; i++)
for (j = 0; j < col; j++) {
if (arr[i][j] == ' ')
return 'N';
}
return 'D';
}
7、Game函数:主要函数写完毕后,用Game函数整体联系起来
int Game() {
char result;
int row = 3, col = 3;
char board[ROW][COL];
InitBoard(board, ROW, COL);
while (1) {
ShowBoard(board, ROW, COL);
WhiteJudge(board, ROW, COL);
result = WinJudge(board, ROW, COL);
switch (result) {
case 'O':
ShowBoard(board, ROW, COL);
printf("恭喜你赢了!\n");
return 0;
case 'X':
ShowBoard(board, ROW, COL);
printf("很抱歉你输了!\n");
return 0;
case 'D':
ShowBoard(board, ROW, COL);
printf("你和电脑是平局!\n");
return 0;
default:
break;
}
printf("\n");
ShowBoard(board, ROW, COL);
Sleep(500);
srand((unsigned long)time(NULL));
BlackJudge(board, ROW, COL);
result = WinJudge(board, ROW, COL);
switch (result) {
case 'O':
ShowBoard(board, ROW, COL);
printf("恭喜你赢了!\n");
return 0;
case 'X':
ShowBoard(board, ROW, COL);
printf("很抱歉你输了!\n");
return 0;
case 'D':
ShowBoard(board, ROW, COL);
printf("你和电脑是平局!\n");
return 0;
default:
break;
}
}
}
头文件函数声明:
为防止跨文件计算机无法找到函数和变量,在头文件中将函数统一声明
#ifndef _CHESS_H
#define _CHESS_H
//三子棋
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
#define ROW 3
#define COL 3
#define BLACKBOARD 'X'
#define WHITEBOARD 'O'
int Game();
void Menu();
void InitBoard(char arr[][COL],int row,int col);
void ShowBoard(char arr[][COL],int row,int col);
void WhiteJudge(char arr[][COL],int row,int col);
void BlackJudge(char arr[][COL],int row,int col);
char WinJudge(char arr[][COL],int row,int col);
#endif
函数定义:
#include"chessh
void Menu() {
printf("********欢迎来到三子棋游戏室********\n");
printf("************************************\n");
printf("***********1、开始游戏**************\n");
printf("***********2、退出游戏**************\n");
printf("************************************\n");
}
void InitBoard(char arr[][COL], int row, int col) {
int i, j;
for (i = 0; i < row; i++)
for (j = 0; j < col; j++) {
arr[i][j] = ' ';
}
}
void ShowBoard(char arr[][COL], int row, int col) {
int i;
printf(" | 1 | 2 | 3 |\n");
for (i = 0; i < row; i++) {
printf("----------------\n");
printf(" %d | %c | %c | %c |\n", i+1, arr[0][i], arr[1][i], arr[2][i]);
}
}
void WhiteJudge(char arr[][COL], int row, int col) {
printf("请选择你要下棋子的坐标");
int x = 0, y = 0;
reselect:
scanf("%d%d", &x, &y);
if (arr[x-1][y-1] == ' ')
arr[x-1][y-1] = WHITEBOARD;
else {
printf("你选择的格子已有棋子,请重选:");
goto reselect;
}
}
void BlackJudge(char arr[][COL],int row, int col) {
while (1) {
int h = rand() % row;
int l = rand() % col;
if (arr[h][l] == ' ') {
printf("电脑落子:%d %d\n", h + 1, l + 1);
arr[h][l] = BLACKBOARD;
break;
}
}
printf("\n");
}
char WinJudge(char arr[][COL], int row, int col) {
int i, j=0;
for (i = 0; i < 3; i++) {
if (arr[i][j] != ' '&&arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2])
return arr[i][0];
}
for (i = 0; i < 3; i++) {
if (arr[0][i] != ' '&&arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i])
return arr[0][i];
}
if (arr[0][0] != ' '&&arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2]) {
return arr[0][0];
}
if (arr[2][0] != ' '&&arr[2][0] == arr[1][1] && arr[1][1] == arr[0][2]) {
return arr[2][0];
}
for (i = 0; i < row; i++)
for (j = 0; j < col; j++) {
if (arr[i][j] == ' ')
return 'N';
}
return 'D';
}
int Game() {
char result;
int row = 3, col = 3;
char board[ROW][COL];
InitBoard(board, ROW, COL);
while (1) {
ShowBoard(board, ROW, COL);
WhiteJudge(board, ROW, COL);
result = WinJudge(board, ROW, COL);
switch (result) {
case 'O':
ShowBoard(board, ROW, COL);
printf("恭喜你赢了!\n");
return 0;
case 'X':
ShowBoard(board, ROW, COL);
printf("很抱歉你输了!\n");
return 0;
case 'D':
ShowBoard(board, ROW, COL);
printf("你和电脑是平局!\n");
return 0;
default:
break;
}
printf("\n");
ShowBoard(board, ROW, COL);
Sleep(500);
srand((unsigned long)time(NULL));
BlackJudge(board, ROW, COL);
result = WinJudge(board, ROW, COL);
switch (result) {
case 'O':
ShowBoard(board, ROW, COL);
printf("恭喜你赢了!\n");
return 0;
case 'X':
ShowBoard(board, ROW, COL);
printf("很抱歉你输了!\n");
return 0;
case 'D':
ShowBoard(board, ROW, COL);
printf("你和电脑是平局!\n");
return 0;
default:
break;
}
}
}
main函数:
#include"chess.h"
int main() {
next:
Menu();
int choice;
int m;
printf("请输入您的选择:");
again:
scanf("%d", &choice);
switch (choice) {
case(1):
while (1) {
Game();
printf("是否要再来一局? 1、再来一局 2、返回菜单\n");
scanf("%d", &m);
if (m == 2)
goto next;
else if (m != 1) {
printf("输入错误,三秒后自动退出!");
Sleep(3000);
break;
}
}
break;
case(2):
break;
default:
printf("输入错误,请重新输入:\n");
goto again;
}
}
至此井字棋代码以全部阐述,快去和你的小伙伴一起玩耍吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
井字棋小游戏c语言简单编码,C语言实现简易井字棋游戏相关推荐
- 井字棋小游戏c语言简单编码,C语言实现井字棋小游戏
C语言实现简单的"井字棋游戏",供大家参考,具体内容如下 总体构造: 1.游戏菜单的逻辑实现 2.游戏本体的代码实现 part 1:游戏菜单的整体逻辑 ①简单的通过一个输入0和1的 ...
- 井字棋小游戏c语言简单编码,井字棋小游戏(C语言)
1 #include 2 #include 3 #include 4 #include 5 #include 6 7 void drawBoard(char *board) //绘制棋盘 8 {9 p ...
- java语言简单代码_java语言编程如何实现一个最简单程序?
在编程语言中,实践出结果是最重要的,其他的什么都是为此做准备,下面我们就来看看该如何编译一个最简单的java程序. 首先,启动你的编程软件,如eclipse等,具体可以网上了解, 再来,创建一个新的j ...
- c 语言简单字符加密,C字符串简易加密解密算法
一. 问题描述 对一个指定的字符串进行加密之后,利用解密函数能后对密文解密显示明文信息,这里定义加密的规则:是将字符串中每个字符加上它在字符串中的位置和一个偏移值.例如:将字符串"mrsof ...
- 什么是c语言内存编码,c语言内存泄露示例解析
正确的内存管理的重要性存在内存错误的 C 和 C++ 程序会导致各种问题.如果它们泄漏内存,则运行速度会逐渐变慢,并最终停止运行:如果覆盖内存,则会变得非常脆弱,很容易受到恶意用户的攻击.从 1988 ...
- linux r语言 指定编码,R语言-进行数据的重新编码(recode)操作
在分析数据时我们经常会遇到将变量值转换成其他的值的情况(如:将连续变量转成分类变量)这时就需要我们对原有数据进行重新编码.本文将介绍R软件中常用的三种重编吗方法: 1.使用逻辑判断式编码. 2.使用c ...
- c语言turbo编码,C语言Turbo C下实现俄罗斯方块
#include #include #include #include #include #ifdef __cplusplus #define __CPPARGS ... #else #define ...
- c语言 行程长度编码,C语言编程题,求大佬帮助,关于数组的。
满意答案 6kidf3xhs 2017.11.07 采纳率:41% 等级:8 已帮助:62人 2 个关键: 2位数字的随机数: a[i]= 10 + rand() % 90; 10位或个位 含5 ...
- c语言前缀编码,C语言实现中缀表达式转前缀表达式
1.实现的基本思想 (1) 初始化两个栈:运算符栈S1和储存中间结果的栈S2: (2) 从右至左扫描中缀表达式: (3) 遇到操作数时,将其压入S2: (4) 遇到运算符时,比较其与S1栈顶运算符的优 ...
- 用Unity3D实现简单的井字棋小游戏
用Unity3D实现简单的井字棋小游戏 项目地址 井字棋小游戏 完成效果图 实现思路 首先定义游戏的数据部分: /* 井字棋中每一个棋格中的逻辑控制常量,代表这个棋格的状态 */ private co ...
最新文章
- Java DatagramSocket(UDP)要注意的问题
- linux设置光标位置,linux下光标定位和输出颜色设置
- arcgis9.2的安装方法
- js进阶 14-8 表单序列化函数serializeArray()和serialize()的区别是什么
- C++学习之路 | PTA乙级—— 1047 编程团体赛 (20 分)(精简)
- 找不到Share Project(Subversion)_android studio
- [Java] 蓝桥杯ALGO-58 算法训练 字串逆序
- [导入]在没有 IIS 的条件下运行 ASMX
- IE无法打开internet网站已终止操作的解决的方法
- 078 周期函数定积分性质及定积分三大性质总结
- python 的statsmodels包,计算Wald tests
- Python_001_旅游评论情感倾向性分析
- 给计算机主机吹灰,电脑主机多久清理一次灰合理一些?一点小建议给你
- python中flush什么意思_python flush()定义及作用详解(实例分析)
- Kahan's summation Formula
- 制作Java视频播放器
- 民宿OTA运营有哪些指标数据最重要
- 会声会影2022最新升级更新版本
- 私域流量有什么特点?
- 机房动环设备集中监控数据运维云平台解决方案