挫逼的扫雷
来源:互联网 发布:网络诈骗案案件徐 编辑:程序博客网 时间:2024/05/02 00:07
(一)思考思路
1:打印棋盘
扫雷(10*10)点出来的数字 是在你点的方块为中心的九宫格里有多少炸弹,那么当在边缘的四个角呢,九宫格里只有三个有效格子,在边缘线呢,也是只有5个有效格子,那么不妨把设成12*12的,但是对最外围不做任何处理
2:游戏过程:
(1)打印棋盘:' 1 '为地雷 ' 0 '为安全
(2)玩家输入
1):判断玩家输入的坐标合法性
输入x,y是否超过数组大小
2):判断是否被炸死
是否被炸死,那么就判断输入的坐标位置的值是否为‘ 1 ’
3):没被炸死,则将周围九宫格内炸弹数打印
其实可以定义两个数组arr 1[12][12] , arr 2[12][12] 一个定义为可见雷阵(1,0) 一个定义梅花(*)
把在可见雷阵上九宫格的炸弹数输入到梅花雷阵里面
(二)代码实现
添加头文件
game.h
#ifndef __GAME_H__#define __GAME_H__#include <stdio.h>#include<string.h>#include <time.h>#include<stdlib.h>#define fire_num 20#define ROWS 10#define COLS 10void put_photo(char arr[ROWS+2][COLS+2],int row,int col);void set_mine(char mine[ROWS+2][COLS+2]);void play_game(char mine[ROWS+2][COLS+2],char show[ROWS+2][COLS+2],int row,int col);#endif //__GAME_H__
游戏细节实现
game.c
#include "game.h"void put_photo(char arr[ROWS+2][COLS+2],int row,int col){int x = 0;int y = 0;printf(" || ");for(x=1;x<row-1;x++){ printf("%d ",x);}printf("\n");for(x=1;x<row-1;x++){printf("%2d| ",x);for(y=1;y<col-1;y++){printf("%c ",arr[x][y]);}printf("\n");}}int get_random_num(int m ,int n){return rand()%(n-m+1)+m;}void set_mine(char mine[ROWS+2][COLS+2]){ int count = fire_num; while(count) { int x = get_random_num(1,10); int y = get_random_num(1,10); if(mine[x][y]=='0') { mine[x][y]='1'; count--; } }}int get_mine_count(char arr[ROWS+2][COLS+2],int x,int y){return ((arr[x-1][y-1]-'0')+ (arr[x][y-1]-'0')+ (arr[x+1][y-1]-'0')+ (arr[x-1][y]-'0')+ (arr[x+1][y]-'0')+ (arr[x-1][y+1]-'0')+ (arr[x][y+1]-'0')+ (arr[x+1][y+1]-'0'));}void play_game(char mine[ROWS+2][COLS+2],char show[ROWS+2][COLS+2],int row,int col){ int win = 0; while(1) { int x = 0, y = 0; printf("请输入行和列:\n"); scanf("%d %d",&x,&y); if((x>=1&&(x<=10))&&((y>=1)&&(y<=10))) { if(mine[x][y]=='1') { printf("game over, hehe\n"); break; } else { int ret = 0; win++; ret = get_mine_count(mine,x,y); show[x][y] = ret + '0'; put_photo(show,ROWS+2,COLS+2); } if(win == COLS*ROWS-fire_num) { printf("胜利!!!\n"); put_photo(mine,ROWS+2,COLS+2); break; } } else { printf("输入错误,请重新输入"); } } }
主函数实现
test.c
#include "game.h"void menu(){printf("--------------------\n");printf("| 1.play game |\n");printf("| 2.exist game |\n");printf("--------------------\n");}void game(){char mine[ROWS+2][COLS+2];char show[ROWS+2][COLS+2];srand((unsigned)time(NULL)); memset(mine, '0', (ROWS+2)*(COLS+2)*sizeof(char));memset(show, '*', (ROWS+2)*(COLS+2)*sizeof(char));set_mine(mine);<span style="font-size:14px;">put_photo(mine,ROWS+2,COLS+2);</span>
printf("\n"); put_photo(show,ROWS+2,COLS+2);
<pre name="code" class="html"> printf("\n");play_game(mine,show,ROWS+2,COLS+2);
<pre name="code" class="html"> put_photo(mine,ROWS+2,COLS+2);}int main() { int input = 0;do {menu();scanf("%d",&input);switch(input){case 1:game();break;case 2:printf("退出游戏中\n");break;default:printf("输出错误,请重新输入\n");}} while (input);return 0;}
0 0
- 挫逼的扫雷
- c简单的扫雷扫雷游戏
- 扫雷游戏的幕后
- 扫雷游戏的秘密
- 扫雷游戏的设计
- 完整的扫雷-Python
- 扫雷不死的秘密
- 我的扫雷程序
- 我的扫雷
- 不一样的扫雷游戏
- 扫雷的启示
- 扫雷的java程序
- JavaScript版的扫雷
- 控制台下的扫雷
- qml 写的扫雷
- 收藏的扫雷
- 扫雷App的实现
- 我的扫雷游戏
- [自考]感想
- AJAX原理
- 乒乓球 codevs1084 洛谷P1042
- 为数字增加千位分隔符 C++实现_使用locale库
- 学习路径之一
- 挫逼的扫雷
- web05jsp
- why docker ?
- 用命令行创建Profile
- C语言笔试题总结3
- 二叉搜索树基本功能实现
- cf调优完整版本
- 第一天开通博客,记录自己的成长生涯
- java毕设--基于jsp servlet开发的在线商城系统