鱼C论坛

 找回密码
 立即注册
查看: 1955|回复: 7

[技术交流] 两天写的扫雷程序 进来看看啊

[复制链接]
发表于 2016-8-16 21:04:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 樱花 于 2016-8-16 21:10 编辑

技术有限  有很多bug
  1. #include "StdAfx.h"
  2. #include <windows.h>
  3. #include <time.h>
  4. int x=0,y=0;
  5. char qipan[9][9]={0};//0代表未掀开■  9代表雷●   ‘0’代表□

  6. //布雷
  7. void 布雷()
  8. {
  9.         srand((unsigned int)time(0));//至随机数种子
  10. for(int i=0;i<10;i++)
  11. {

  12.         while(1)
  13.         {
  14.                 x=rand()%9;
  15.                 y=rand()%9;
  16.                 if(qipan[x][y]!='9')
  17.                 {       
  18.                         qipan[x][y]='9';
  19.                         break;
  20.                 }


  21.         }
  22. }
  23. }

  24. //先输出雷  游戏做好后注释掉
  25. void 布局分析2()
  26. {
  27. for(int i=0;i<9;i++)
  28. {
  29.         for(int j=0;j<9;j++)
  30.         {
  31.                 if(qipan[i][j]=='9')
  32.                         printf("●");
  33.                 else
  34.                         printf("■");
  35.         }
  36.         printf("\n");
  37. }
  38. }

  39. //计算当前九宫格的雷数
  40. int 计算雷数(int a,int b)
  41. {       
  42.         int i=0,j=0,lei=0;
  43.         for(i=a-1;i<=a+1;i++)
  44.         {
  45.                 for(j=b-1;j<=b+1;j++)
  46.                 {
  47.                         if (qipan[i][j]=='9' && i>=0 && j>=0 && i<=8 && j<=8)
  48.                                 lei++;
  49.                                
  50.                 }
  51.         }
  52.         return lei;

  53. }

  54. //扫雷
  55. int 扫雷(int a,int b)
  56. {
  57.         int lei=0,i,j;
  58.         if (qipan[a][b]=='9')
  59.         {
  60.                 printf("踩到雷了,游戏结束!\n");
  61.                 exit(0);
  62.         }
  63.         lei=计算雷数(a,b);
  64.         //printf("雷数:%d\n",lei);
  65.         if (lei>0)
  66.         {        //这里求教
  67.                 if(lei==1)       
  68.                          qipan[a][b]=49;
  69.                 if(lei==2)       
  70.                          qipan[a][b]=50;
  71.                 if(lei==3)       
  72.                          qipan[a][b]=51;
  73.                 if(lei==4)       
  74.                          qipan[a][b]=52;
  75.                 if(lei==5)       
  76.                          qipan[a][b]=53;
  77.                 if(lei==6)       
  78.                          qipan[a][b]=54;
  79.                 if(lei==7)       
  80.                          qipan[a][b]=55;
  81.                 if(lei==8)       
  82.                          qipan[a][b]=56;
  83.                 return 1;
  84.         }
  85.         else
  86.         {
  87.                 //47分钟
  88.                 qipan[a][b]='0';
  89.                 for(i=a-1;i<=a+1;i++)
  90.                 {
  91.                         for(j=b-1;j<=b+1;j++)
  92.                         {
  93.                                 if(qipan[i][j]==0 && i>=0 && j>=0 && i<=8 && j<=8)
  94.                                 扫雷(i,j);
  95.                         }
  96.                 }
  97.                
  98.         }
  99. }

  100. //布局分析
  101. void 布局分析()
  102. {
  103. for(int i=0;i<9;i++)
  104. {
  105.         for(int j=0;j<9;j++)
  106.         {
  107.                 if(qipan[i][j]==0 || qipan[i][j]=='9')
  108.                         printf("■");
  109.                 else if(qipan[i][j]=='0')
  110.                         printf("□");
  111.                 else
  112.                         printf("%c ",qipan[i][j]);
  113.         }
  114.         printf("\n");
  115. }
  116. }

  117. //判断是否结束
  118. int 是否结束()
  119. {
  120.         for(int i=0;i<9;i++)
  121.         {
  122.                 for(int j=0;j<9;j++)
  123.                 {
  124.                         if (qipan[i][j]==0)
  125.                         {
  126.                                 return -1;
  127.                         }
  128.                         else
  129.                         {
  130.                                 return 1;
  131.                         }
  132.                 }
  133. }
  134. }



  135. int _tmain(int argc, _TCHAR* argv[])
  136. {
  137.         //布雷
  138.         布雷();
  139.         //输出雷的位置  更好的查看
  140.         //布局分析2();
  141.         布局分析();
  142.         while(1)
  143.         {
  144.                 printf("请输入x,y坐标:");
  145.                 scanf("%d,%d",&x,&y);//英文逗号分隔
  146.                 扫雷(x,y);
  147.                 布局分析();
  148.                 if (是否结束()==-1)
  149.                 {
  150.                         printf("恭喜扫雷完成\n");
  151.                 }
  152.         }
  153.         return 0;
  154. }
  155. bug发到下边
  156. 文件太大  没法上传  百度云
  157. 链接: http://pan.baidu.com/s/1ge4aw2R 密码: pcjz
复制代码
QQ截图20160816205317.png

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
宝贝归来 + 5 + 5 + 3 感谢楼主无私奉献!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-8-16 21:12:07 | 显示全部楼层
厉害 膜拜
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-8-16 21:14:43 | 显示全部楼层
中文函数呀
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-8-16 21:51:29 | 显示全部楼层


不懂英文
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-8-17 11:29:02 | 显示全部楼层
怎么没人呀     来凑个人数
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-8-18 23:55:41 | 显示全部楼层
不懂怎么玩
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-8-19 11:04:16 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-8-20 11:00:35 | 显示全部楼层
应该加个非法输入判断的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-13 21:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表