// C语言版本扫雷
#include <stdio.h> #include <stdlib.h> /*
1(0,0) 1(0,1) 0(0,2) 1(0,3) 1(0,4)
@(1,0) 2(1,1) 1(1,2) 2(1,3) @(1,4)
1(2,0) 2(2,1) @(2,2) 3(2,3) 2(2,4)
0(3,0) 1(3,1) 3(3,2) @(3,3) 2(3,4)
0(4,0) 0(4,1) 2(4,2) @(4,3) 2(4,4) */
void bomb(void) {
//扫雷 是一个矩形图形 可以用二维数组存储数据
//存放雷 和 周围雷的个数
int a[5][5] = {}; //记录5*5的矩阵中的坐标 有没有输入过
int b[5][5] = {}; /* 判断输入雷的个数是否正确 不正确继续输入
while (1) {
printf("请输入雷的个数:(1-24)\n");
int bombNumber;
scanf("%d",&bombNumber);
if (bombNumber>=1&&bombNumber<=24) {
break;
}
}
*/
//方法2:
//标签
InPutLabel:
printf("请输入雷的个数:(1-24)\n");
int bombNumber;
scanf("%d",&bombNumber);
if (bombNumber>=1&&bombNumber<=24) {
//输入正确
}else{
//输入的超出范围
goto InPutLabel;//goto 跳转语句
//跳转到InPutLabel标签的位置 开始执行
}
/*
@****
*****
**@**
****@
*****
*/
//摆擂 有多少个雷 那么就随机产生多少个雷(坐标不能一样)
for (int i = 0; i < bombNumber; i++) {
//随机产生坐标 坐标范围(0-4,0-4)
int x = arc4random()%5;
int y = arc4random()%5;
//数字转化为数字字符 1+'0' -->'1'
//判断随机坐标有没有摆过雷
if (a[x][y] != '@'-'0') {
//布擂 '@'-'0'表示雷
a[x][y] = '@'-'0';
//遍历雷的周围 让周围雷数+1 遍历九宫格 的八个方向
//遍历 雷周围的矩阵
for (int m = x-1; m <= x+1; m++) {
for (int n = y-1; n <= y+1; n++) {
//判断边界 和周围是不是雷
if (m<0||m>4||n<0||n>4||a[m][n]=='@'-'0') {//超出边界 或者是雷
//雷数不能+1; }else{
a[m][n]++;
} }
}
}else{
//随机的恰好已经布过雷了得坐标
i--;//重新随机
}
}
//布雷之后
//开始玩游戏
//记录输入坐标的个数
int count = 0;
int winOrLose = 1;//1表示成功 0表示失败
//循环输入 坐标
while (1) {
system("clear");
//打印矩阵 5*5
for (int i = 0; i < 5; i++) {
for (int j = 0; j < 5; j++) {
if (1 == b[i][j]) {//判断这个坐标有没有输入过
//1表示输入过 那么就打印雷数 否则打印?
//\t是一个制表符
printf("%c(%d,%d)\t",a[i][j]+'0',i,j);
}else{
printf("?(%d,%d)\t",i,j);
}
}
printf("\n");
}
printf("请输入坐标:例如 2 4\n");
int bombX;
int bombY;
scanf("%d%d",&bombX,&bombY);
//判断是否是雷
if (a[bombX][bombY] == '@'-'0') {
//雷
winOrLose = 0;//失败
break;//跳出循环
}
//不是雷 那么 执行下面
if (b[bombX][bombY] != 1) {//判断坐标有没有输入过
//1表示输入过 0 表示没有
b[bombX][bombY] = 1;//记录输入过 count++;//无重复坐标个数
}
if (count == 5*5-bombNumber) {
//表示扫雷成功
winOrLose = 1;
break;
}
}
//结束之后再打印一次矩阵 for (int i = 0; i < 5; i++) {
for (int j = 0; j < 5; j++) {
if (1 == b[i][j]||winOrLose == 0) {
//如果坐标输入过 或者 失败了 显示出来数字或者是雷
printf("%c(%d,%d)\t",a[i][j]+'0',i,j);
}else{
printf("?(%d,%d)\t",i,j);
}
}
printf("\n");
}
if (winOrLose) {//1
printf("小样!技术不错...再接再厉\n");
}else{
printf("你得游戏是地理老师教得吧!\n");
}
return;
} int main(int argc, const char * argv[])
{
bomb();
return 0;
}

C 碎片十一 扫雷源码的更多相关文章

  1. 台哥原创:java 扫雷源码

    扫雷,十年前大学时候开发的,界面参照的电脑自带扫雷游戏. 一直是我最喜欢的单机游戏,现在微软的新系统都不能玩了. 幸好还有自己开发的,可以过下瘾.程序员就有这点好处嘛. ​ 这几年陆陆续续,把这个扫雷 ...

  2. 从壹开始微服务 [ DDD ] 之十一 ║ 基于源码分析,命令分发的过程(二)

    缘起 哈喽小伙伴周三好,老张又来啦,DDD领域驱动设计的第二个D也快说完了,下一个系列我也在考虑之中,是 Id4 还是 Dockers 还没有想好,甚至昨天我还想,下一步是不是可以写一个简单的Angu ...

  3. 十一.jQuery源码解析之.pushStack()

    pushStack()顾明思意,就是像桟中添加东西呗,现在看看他是如何添加东西的. 创建一个空的jQuery对象,然后把Dom元素集合放入这个jQuery对象中, 并保留对当前jQuery对象的引用. ...

  4. JAVA上百实例源码以及开源项目

    简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级.中级.高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情.执着,对IT的憧憬. ...

  5. JAVA上百实例源码网站

    JAVA源码包1JAVA源码包2JAVA源码包3JAVA源码包4 JAVA开源包1 JAVA开源包2 JAVA开源包3 JAVA开源包4 JAVA开源包5 JAVA开源包6 JAVA开源包7 JAVA ...

  6. jQuery-1.9.1源码分析系列(十一) DOM操作

    DOM操作包括append.prepend.before.after.replaceWith.appendTo.prependTo.insertBefore.insertAfter.replaceAl ...

  7. APP源码集中打包大放送!十一个千万级别APP源码随意处置!

    小伙伴们还在一个一个苦苦寻找各类APP源码吗?此贴集中打包最常用APP的源码,你想得到的APP,这里都有! 想做商城?这里有天猫! 想做同城服务?这里有大众点评! 想做外卖?这里有饿了么! 想做视频? ...

  8. 手机自动化测试:appium源码分析之bootstrap十一

    手机自动化测试:appium源码分析之bootstrap十一   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣 ...

  9. Python:游戏:扫雷(附源码)

    这次我们基于 pygame 来做一个扫雷,上次有园友问我代码的 python 版本,我说明一下,我所有的代码都是基于 python 3.6 的. 先看截图,仿照 XP 上的扫雷做的,感觉 XP 上的样 ...

随机推荐

  1. asp中实现lable自动换行

    asp中实现lable自动换行 因为在用Label标签显示内容时,内容太多,想实现自动换行.我们知道在WINFORM中程序中,有一个属性是AUTOSIZE 改成FALSE 是可以实现的.但是在ASP. ...

  2. 关于 sklearn.decomposition.KernelPCA的简单介绍

    from sklearn import decomposition import numpy as np A1_mean = [1, 1] A1_cov = [[2, .99], [1, 1]] A1 ...

  3. centos7 firewalld使用

    转 http://blog.csdn.net/jamesge2010/article/details/52449678 1.firewalld的基本使用 启动: systemctl start fir ...

  4. sort,uniq,cut,wc命令详解

    sortsort 命令对 File 参数指定的文件中的行排序,并将结果写到标准输出.如果 File 参数指定多个文件,那么 sort 命令将这些文件连接起来,并当作一个文件进行排序. sort语法 s ...

  5. xdu2017校赛F

    Problem F Dogs of Qwordance Senior Backend R&D Engineers 问题描述 那年夏天,锘爷和杰师傅漫步在知春公园的小道上.他们的妻子.孩子牵 着 ...

  6. BeanFactory和ApplicationContext的介绍

    ------------------siwuxie095                             Spring 通过一个配置文件描述 Bean 和 Bean 之间的依赖关系, 利用 J ...

  7. JS使用replace替换字符串中的某段或某个字符

    函数的介绍参考:http://www.w3school.com.cn/jsref/jsref_replace.asp 下列代码将Hello World!中的World替换为Jim <html&g ...

  8. C++哪些函数不能是虚函数

    1. inline是编译时展开,必须有实体:(不考虑不展开的假inline)   2. static属于class自己的,也必须有实体:   3. 构造函数.复制构造函数.virtual函数基于vta ...

  9. bzoj2502: 清理雪道(有源汇有上下界最小流)

    传送门 别说话,自己看,我不会->这里 我这里用的建图方法是先跑一次最大流,连上$(t,s,inf)$之后再跑一遍,然后答案就是之前连的那条边的反向边的流量 据说还有种方法是连上$(t,s,in ...

  10. 对zabbix监控磁盘性能的补充

    原因 在上一篇文章中,我写了完整的磁盘监控步骤,希望对大家有所帮助.但是这里还需要作出一点补充. 根据上一篇文章的内容,我是使用iostat命令不停的收集磁盘的信息,然后写入到/tmp/iostat_ ...