本文将利用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++ 数据结构超详细讲解顺序表 2023-03-25
- 详解C语言中sizeof如何在自定义函数中正常工作 2023-04-09
- Qt计时器使用方法详解 2023-05-30
- C语言手把手带你掌握带头双向循环链表 2023-04-03
- 我应该为我的项目使用相对包含路径,还是将包含目录放在包含路径上? 2022-10-30
- Easyx实现扫雷游戏 2023-02-06
- C语言详解float类型在内存中的存储方式 2023-03-27
- c++ const 成员函数,返回一个 const 指针.但是返回的指针是什么类型的 const? 2022-10-11
- C语言qsort()函数的使用方法详解 2023-04-26
- ubuntu下C/C++获取剩余内存 2023-09-18