当前位置: 首页 > news >正文

C语言最简单的扫雷实现(解析加原码)

头文件

#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define numlei 10

do while可以循环玩
两个板子,内板子放0,外板子放*
set函数初始化两个板子
lei函数,x,y随机两数,把内板子某些0改为1
print函数打印内或外板子
board返回周围8个格子雷的个数

#include "game.h"
void set(char arr[ROWS][COLS], int row, int col,char set)
{for (int i = 0;i < ROWS;i++){for (int j = 0;j < COLS;j++){arr[i][j] = set;}}
}
void lei(char arr[ROWS][COLS], int row, int col)
{int count = numlei;while (count){int x = rand() % 9 + 1;int y = rand() % 9 + 1;if (arr[x][y]=='0'){arr[x][y] = '1';count--;}}
}
void print(char arr[ROWS][COLS], int row, int col)
{for (int i=0;i<=row;i++){printf("%d ",i);}printf("\n");for (int i = 1;i <= row;i++){printf("%d ", i);for (int j = 1;j <= col;j++){   printf("%c ", arr[i][j]);}printf("\n");}
}
int board(char mine[ROWS][COLS], int x, int y)
{return  (mine[x - 1][y] + mine[x - 1][y - 1] + mine[x][y - 1] + mine[x + 1][y-1] + mine[x + 1][y] + mine[x + 1][y + 1] + mine[x][y + 1] + mine[x - 1][y + 1]-8*'0');}void game()
{printf("********************\n");printf("**** 1.游戏开始 ****\n");printf("**** 0.退出游戏 ****\n");printf("********************\n");int input;char show[ROWS][COLS];char inside[ROWS][COLS];do{scanf("%d", &input);switch (input){case 1:printf("游戏开始\n");set(show, ROW, COL, '*');print(show, ROW, COL);set(inside, ROW, COL, '0');lei(inside, ROW, COL);int win = 0;while (win<ROW*COL-numlei){int x, y;scanf("%d %d", &x, &y);if (x >= 1 && y >= 1 && x <= ROW && y <= COL){if (inside[x][y] == '1'){printf("你被炸了\n");print(inside, ROW, COL);break;}else{int c = board(inside, x, y);show[x][y] = c + '0';print(show, ROW, COL);win++;}}elseprintf("输入坐标错误,请重新输入\n");}if (win == ROW * COL - numlei){printf("排雷成功\n");print(inside, ROW, COL);}break;case 0:printf("退出游戏\n");break;default:printf("重新输入\n");break;}} while (input);
}int main()
{   srand((unsigned) time(NULL));game();return 0;
}
http://www.lryc.cn/news/481562.html

相关文章:

  • 20. 类模板
  • SSL证书以及实现HTTP反向代理
  • 多种算法解决组合优化问题平台
  • 【笔记】LLC电路工作频点选择 2-1 输出稳定性的限制
  • Linux系统程序设计--2. 文件I/O
  • 右值引用——C++11新特性(一)
  • JavaScript 观察者设计模式
  • 鸿蒙进阶篇-网格布局 Grid/GridItem(二)
  • 数据仓库之 Atlas 血缘分析:揭示数据流奥秘
  • AndroidStudio-滚动视图ScrollView
  • 嵌入式硬件实战基础篇(一)-STM32+DAC0832 可调信号发生器-产生方波-三角波-正弦波
  • ElasticSearch的Python Client测试
  • 【eNSP】企业网络架构链路聚合、数据抓包、远程连接访问实验(二)
  • 独立站 API 接口的性能优化策略
  • 不一样的CSS(一)
  • 题目:Wangzyy的卡牌游戏
  • 国外云服务器高防多少钱一年?
  • 架构篇(04理解架构的演进)
  • 【363】基于springboot的高校竞赛管理系统
  • Spring Boot 监视器
  • Javascript如何获取指定网页中的内容?
  • 第2章2.3立项【硬件产品立项的核心内容】
  • 区块链:Raft协议
  • 【C语言】位运算
  • 计算机体系结构之多级缓存、缓存miss及缓存hit(二)
  • 【R78/G15 开发板测评】串口打印 DHT11 温湿度传感器、DS18B20 温度传感器数据,LabVIEW 上位机绘制演化曲线
  • Oracle Fetch子句
  • Linux应用——线程池
  • 95.【C语言】数据结构之双向链表的头插,头删,查找,中间插入,中间删除和销毁函数
  • leetcode82:删除排序链表中的重复节点||