本文将利用C语言编写一个n字棋游戏,和井字棋一样,不过这个游戏你可以自定义棋盘的大小。文中的示例代码讲解详细,感兴趣的小伙伴可以尝试一下
前言
这里就简单发一个n字棋游戏,和井字棋一样,不过这个游戏你可以自定义棋盘的大小。
井字棋是3×3大小,满足三个平齐就获得胜利。
小奔写的这个游戏,你可以自定义为10×10大小,满足6个平齐就获得胜利,都是可以随便定义的。
如果感兴趣的话就可以来尝试一下,或许你可以找到一些bug

(至于为什么说它是“人工智障”呢?因为它是随机下的,并不会去针对你,它很有自己的想法,不过有一次小奔测试的时候,没有注意到,就被它反杀了……)
思路
- 用#define定义的标识符常量来确定n字棋的大小和n字棋获胜的条件
- 打印一个开始面板
- 选择是否开始游戏
- 开始游戏
- 根据#define定义的标识符常量来创建二维数组
- 把二维数组初始化为空格
- 打印一个n字棋的面板
- 游戏者输入坐标
- 判断游戏者输入的坐标是否已输入,已输入就重新输入
- 未输入的话,把O记录到数组里选择的坐标上
- 判断游戏者是否获得胜利,胜利结束游戏
- 判断是否填满了表格,填满就平局
- 电脑根据随机值输入坐标
- 判断电脑输入的坐标是否已输入,已输入就重新输入
- 未输入的话,把X记录到数组里选择的坐标上
- 判断电脑是否获得胜利,胜利结束游戏
- 判断是否填满了表格,填满就平局
- 回到步骤7,不断循环,直到某方获胜或者平局
- 结束后输入1重新开始游戏,输入0结束游戏
你看懂了吗?
效果图
这里的自定义的是10×10大小的,胜利条件是大于等于5,游戏方使用的是大写O
开始的界面

棋盘的样子

随机打的坐标

获得胜利

结束程序

怎么样,感觉还不错吧,还不快去支持一下小奔
代码
创建了两个.c文件test.c和game.c,一个头文件game.h
test.c
#define _CRT_SECURE_NO_WARNINGS
#include"game.h"
int main()
{
int num = 1;
srand((unsigned int)time(NULL));
do
{
if (num == 1)
{
//打印一个开始面板
playboard();
}
printf("输入1则进行游戏,输入0则结束程序\n");
//输入选择
num = choose();
//通过输入的选择来判断是否进行游戏
switch (num)
{
case 1://开始游戏
{
do
{
playgame();
num = 0;
printf("是否重新开始游戏,重新开始输入1,结束游戏输入0:>");
scanf("%d", &num);
if (num == 1)
;
else if (num == 0)
break;
else
printf("输入错误,");
} while (1);
break;
}
case 0:
{
printf("结束程序\n");
break;
}
default:
{
printf("\n输入错误,未能识别你的选择,请重新输入\n\n");
break;
}
}
//判断是否跳出循环
if (num == 0)
break;
} while (1);
return 0;
}
game.c
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#define WID 10
#define NID 10
#define SIC 5
void playboard()
{
printf("**********************************\n");
printf("**********************************\n");
printf("************ 1.play **************\n");
printf("************ 0.exit **************\n");
printf("**********************************\n");
printf("**********************************\n");
}
int choose()
{
int num = 0;
printf("请输入你的选择:>");
scanf("%d", &num);
return num;
}
void space(char arr[WID][NID], int x, int y)
{
int i = 0;
for (i = 0; i < x; i++)
{
int j = 0;
for (j = 0; j < y; j++)
{
arr[i][j] = ' ';
}
}
}
board(char arr[WID][NID],int x,int y)
{
int i = 0;
int j = 0;
printf("\n-");
for (i = 0; i < x; i++)
{
printf("----");
}
printf("-\n");
printf("0");
for (i = 1; i <= x; i++)
{
printf(" %d ", i);
}
printf("\n");
printf("-");
for (i = 0; i < x; i++)
{
printf("----");
}
printf("-\n");
for (i = 0; i < x; i++)
{
int k = 0;
printf("%d", i+1);
for (j = 0; j < y; j++)
{
printf("|");
printf(" %c ", arr[i][j]);
}
printf("|\n");
printf("-");
for (k = 0; k < x; k++)
{
printf("----");
}
printf("-\n");
}
}
void axis(int* x,int* y)
{
scanf("%d %d", &*x, &*y);
*x=(*x) - 1;
*y=(*y) - 1;
}
void sure(char arr[WID][NID],int x,int y,char c)
{
arr[x][y] = c;
}
void human_machine(int* x, int* y)
{
*x = rand() % WID;
*y = rand() % NID;
}
int judge(char arr[WID][NID],int x,int y)
{
if (arr[x][y] == ' ')
return 0;
else
return 1;
}
int judgesure(char arr[WID][NID], int x, int y,char siz)
{
int count = 0;
int i = 0;
for (i = 1; i <= y; i++)
{
if (arr[x][y - i] == siz)
count++;
else
break;
}
for (i = 1; i <= NID-y-1; i++)
{
if (arr[x][y + i] == siz)
count++;
else
break;
}
if (count >= SIC - 1)
return 1;
count = 0;
for (i = 1; i <= x; i++)
{
if (arr[x-i][y] == siz)
count++;
else
break;
}
for (i = 1; i <= NID - x-1; i++)
{
if (arr[x+i][y ] == siz)
count++;
else
break;
}
if (count >= SIC - 1)
return 1;
count = 0;
if (WID >= NID)
{
for (i = 1; i <= y; i++)
{
if (arr[x - i][y - i] == siz)
count++;
else
break;
}
for (i = 1; i <= NID - y - 1; i++)
{
if (arr[x + i][y + i] == siz)
count++;
else
break;
}
if (count >= SIC - 1)
return 1;
count = 0;
for (i = 1; i <= y; i++)
{
if (arr[x + i][y - i] == siz)
count++;
else
break;
}
for (i = 1; i <= NID - y - 1; i++)
{
if (arr[x - i][y + i] == siz)
count++;
else
break;
}
if (count >= SIC - 1)
return 1;
count = 0;
}
if (WID <= NID)
{
for (i = 1; i <= x; i++)
{
if (arr[x - i][y - i] == siz)
count++;
else
break;
}
for (i = 1; i <= NID - x; i++)
{
if (arr[x + i][y + i] == siz)
count++;
else
break;
}
/
沃梦达教程
本文标题为:利用C语言实现n字棋游戏
基础教程推荐
猜你喜欢
- C语言数组长度的计算方法实例总结(sizeof与strlen) 2023-04-26
- C语言的三种条件判断语句你都了解吗 2023-03-05
- VisualStudio2010安装教程 2023-01-05
- Qt数据库应用之实现通用数据库请求 2023-03-18
- 纯C++代码详解二叉树相关操作 2023-05-15
- 05-C语言进阶——动态内存管理 2023-11-20
- g++: const 丢弃限定符 2022-10-07
- C语言植物大战数据结构二叉树递归 2023-04-09
- character-encoding – Linux中最常见的C语言编码(和Unix?) 2023-11-21
- 利用QT设计秒表功能 2023-05-30
