// 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. Load Runner 变量、参数的简单使用

    Action(){ 定义数组时一定要指明大小 变量定义一定要放在所以操作之前,放在脚本最前面     int num ;//定义数值变量 int numy[5];//定义整型数组 char *str1 ...

  2. 杭电acm 1034题

    Problem Description A number of students sit in a circle facing their teacher in the center. Each st ...

  3. R中的统计模型

    R中的统计模型 这一部分假定读者已经对统计方法,特别是回归分析和方差分析有一定的了解.后面我们还会假定读者对广义线性模型和非线性模型也有所了解.R已经很好地定义了统计模型拟合中的一些前提条件,因此我们 ...

  4. 荧光分子的dynamic quenching 和 通常说的quenching的区别?

    quenching有两种,学术上分为dynamic quenching 和static quenching,我们通常说的quenching就是 static quenching. static que ...

  5. 浅谈js模块加载方式(初级)

    1.简介:  前端模块化开发日渐鼎盛,如何将零散的插件或者是普通的js脚本文件统一管理及引用,是众多开发者共同的目标.本人是从事.net开发的,最近对前端的一些东西特别的感兴趣,也会尝试的夹杂一点自己 ...

  6. EasyUI 在mvc中的引入与使用

    使用步骤: 一.先引入: 1.easyui下载,可以去官方网站去下载最新版EasyUI官方下载地址:http://www.jeasyui.com/download/index.php 2.下载后解压, ...

  7. es6- Generator函数实现长轮询

    1.Generator 函数是 ES6 提供的一种异步编程解决方案,语法行为与传统函数完全不同. 语法上,首先可以把它理解成,Generator 函数是一个状态机,封装了多个内部状态.形式上,Gene ...

  8. python之01电脑和操作系统简史

    电脑简史 早期计算方式发展 :手指和石头 ->结绳 ->算筹->计算尺 -> 算盘 19岁时(1642),帕斯卡发明了人类有史以来第一台机械计算机——帕斯卡加法器.它是一种系列 ...

  9. java 多线程学习笔记(二) -- IO密集型任务

    IO密集型是指对IO操作较多的任务.下面以查询一些股票价格任务为例: YahooFinance.java public class YahooFinance { public static doubl ...

  10. poj 1655 Balancing Act(找树的重心)

    Balancing Act POJ - 1655 题意:给定一棵树,求树的重心的编号以及重心删除后得到的最大子树的节点个数size,如果size相同就选取编号最小的. /* 找树的重心可以用树形dp或 ...