欢迎各位点赞👍评论✍收藏⭐
引言:
扫雷的博客-->【扫雷+全部码源】C语言详解,进来你就会,保姆级!!!_扫雷宝公式源码-CSDN博客
关于扫雷,一定有很多宝子有很多问题,我这里总结几个问题,可以更好帮助你理解扫雷!
目录
1. 为什么用两个数组
在扫雷中,我们要创建两个数组
char mine[ROWS][COLS]={ 0 }; //埋雷数组
char show[ROWS][COLS]={ 0 }; //展示数组
首先我们要知道埋雷数组中用字符0初始化,用字符1当作地雷,如图:
返回的1和地雷字符 ‘1’,有歧义,所以用另一个数组来接收返回的数字
2. 为什么要在外面加一行
如果没有在外面加一行 ,可以看到在下面的雷下面三个不存在,或者造成数组的越界
加了一行后,就可统计之前数组越界的问题了
3. 为什么用字符 0 和字符 1
首先要知道:
数字和字符相互转换,即
'100' - '0' = 100 100 + '0' = '100'
用字符 0 和 1,不是为了好看,而是方便计算地雷的个数
计算红色方框的地雷的个数,假设中间坐标为(x,y)那雷的个数就为:
(mine[x-1][y-1]+mine[x-1][y]+
mine[x-1][y+1]+mine[x][y-1]+
mine[x][y+1]+mine[x+1][y-1]+
mine[x+1][y]+mine[x+1][y+1]-8*'0')
也就刚好返回地雷的个数,最后的 ’-8*'0' ’ 就是字符转换为数字
4. 小结
以上就是对扫雷的分析,具体还需宝子们去实践,如果觉得该博客对你有用的话,希望一键三连,点个关注不迷路,谢谢支持!