#include<stdio.h>
//使用二维数组实现 扫雷
int main()
{

   char ui[8][8]={
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+',
                  '+','+','+','+','+','+','+','+'
                 };
   int map[8][8]={
                     0,0,0,0,0,0,0,0,
                     0,0,1,0,0,1,0,0,
                     0,0,0,0,1,0,0,0,
                     0,0,0,0,0,1,0,0,
                     0,0,1,0,0,0,0,0,
                     0,0,1,0,0,0,0,0,
                     0,1,0,1,1,0,0,0,
                     1,0,0,0,0,0,0,0
                     };
   int p[8][2]={{-1,-1} ,{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1}};
   int i=0,j=0;
   int h=0,l=0;
   int h1=0,l1=0;
   int n=0;//用来保存 雷的数量 计数
   int win=0;
 while(1)
  {
       printf("    扫雷游戏\n");

          for(i=0;i<8;i++)
            {
              for(j=0;j<8;j++)
                {
                  printf("%c ",ui[i][j]);
                }
               printf("\n");
           }

      printf("请输入你要打开的位置 行 列:");
          scanf("%d%d",&h,&l);
         if(map[h-1][l-1]==1)
          {
              printf("踩到雷 游戏结束\n");
                break;
          }
         h=h-1;
         l=l-1; 

         //没有踩到雷的情况  判断周围有几个雷 并把数字显示在 界面上
         //-1 -1    -1, 0   -1,+1   0 ,-1   0 ,+1   +1 ,-1    +1,0   +1 ,+1 

        //n=map[h-1][l-1]+map[h-1][l]+map[h-1][l+1]+map[h][l-1]+map[h][l+1]+map[h+1][l-1]+map[h+1][l+1]+map[h+1][l];
        i=0;

        while(i<8)
         {
             n=0;
             h1=h;
             l1=l;
             h1= h1+p[i][0];
             l1=l1+p[i][1];
             if(h1>=0&&h1<8&&l1>=0&&l1<8)
               {
                    if(map[h1][l1]==1)
                        {
                           n++;
                        }
               }

             i++;
          }

         //把得到的数字显示到 界面上 ui[h][l];
         //把int数字转换成 字符
         switch(n)
           {
                case 0:
                    ui[h][l]='0';
                       break;
                case 1:
                    ui[h][l]='1';
                       break;
                case 2:
                    ui[h][l]='2';
                       break;
                case 3:
                    ui[h][l]='3';
                       break;
                case 4:
                    ui[h][l]='4';
                       break;
                case 5:
                    ui[h][l]='5';
                       break;
                case 6:
                    ui[h][l]='6';
                       break;
                case 7:
                    ui[h][l]='7';
                       break;
                case 8:
                    ui[h][l]='8';
                       break;
           }
           win++;
           if(win==54)
             {
                printf("获胜 游戏结束\n");
                   break;
             }
   }
  return 0;
}

C语言二维数组实现扫雷游戏的更多相关文章

  1. c语言二维数组传递

    c语言二维数组传递,目前我总结三种方法,以及纠正一个不能使用的方法 /********************************* * 方法1: 第一维的长度可以不指定 * * 但必须指定第二维 ...

  2. 关于c语言二维数组与指针的个人理解及处理办法。

    相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...

  3. C语言 二维数组复制、清零及打印显示

    #include <stdlib.h> #include <stdio.h> #include <string.h> //二维整型数组打印显示 ],int row, ...

  4. C语言二维数组作业

    一.PTA实验作业 题目1:7-3 出生年 1. 本题PTA提交列表 2. 设计思路 1.声明一个函数different()用来计算一个年份的不同数字个数 2.定义y(y是来计算符合要求的年份的量), ...

  5. C语言 二维数组(指针)动态分配和释放(转)

    C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...

  6. C语言二维数组

    上节讲解的数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多数据是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本节只介绍二维数 ...

  7. C语言二维数组作为函数参数

    设有整型二维数组a[3][4]如下:0   1   2   34   5   6   78   9  10  11 它的定义为:    int a[3][4]={{0,1,2,3},{4,5,6,7} ...

  8. C语言二维数组作为函数的参数

    前言:今天在实现装配线调度程序时候,用到了二维数组,并将其作为函数的参数.在写程序的时候,遇到一些问题,即二维数组做函数的参数应该如何正确表示.我写程序的错误如下程序所示: #include < ...

  9. c语言二维数组与指针

    问题,以下输出的结果是什么,区别在于哪? void main() { ][] = { ,,,,,,,,,,, }; //输出的3个地址都一样,差别在哪? printf("\n%x" ...

随机推荐

  1. 使用Fresco实现简单的显示一张图片

    使用Fresco实现显示一张图片 仅仅是下载一张图片,在下载完之前,先显示一张站位图 效果图 源码 下载地址(Android Studio工程):http://download.csdn.net/de ...

  2. Hadoop:Hadoop单机伪分布式的安装和配置

    http://blog.csdn.net/pipisorry/article/details/51623195 因为lz的linux系统已经安装好了很多开发环境,可能下面的步骤有遗漏. 之前是在doc ...

  3. 18 UI美化状态集合的位图selector

    当我们某个控件 想在不同状态下显示不同的背景图的需求 如我们需要按钮在正常状态显示一种图 按下显示另一背景图 或者单选框被选中时是一种显示图片 没选中是另一种背景图 例子 按钮在不同状态显示不同的背景 ...

  4. 同步图计算:GraphLite的安装和使用

    http://blog.csdn.net/pipisorry/article/details/51350908 export HADOOP_HOME=/usr/local/hadoop-2.6.4ex ...

  5. RPCZ中的智能指针单例

    RPCZ中的智能指针单例 (金庆的专栏) 智能指针单例应用于 RPCZ 库以实现库的自动初始化与自动清理. RPCZ: RPC implementation for Protocol Buffers ...

  6. 套接字输入缓冲装置——InternalInputBuffer

    互联网的世界很复杂,信息从一端传向另一端过程也相当复杂,中间可能通过若干个硬件,为了提高发送和接收效率,在发送端及接收端都将引入缓冲区,所以两端的套接字都拥有各自的缓冲区,当然这种缓冲区的引入也带来了 ...

  7. Java --Annotation学习心得体会及笔记

    相对于注释这种给程序员看的信息: 注解,就是给程序看的解释性的语言,其作用就相当于配置文件的存在.其存在的意义在于以下几点: 优点: 方便的使程序员看到相关项的关联位置及关联方式等信息. 缺点: 由于 ...

  8. Dubbo粗浅记录

    这篇博客只是我自己的学习记录,对各位高手怕是没有什么太大的帮助,望高手不吝赐教. 项目的截图如下: 我们使用的主要就是红框里面的. 这里我主要分析两个xml /DubboTest/src/main/r ...

  9. Android Studio重构之路,我们重新来了解一下Google官方的Android开发工具

    Android Studio重构之路,我们重新来了解一下Google官方的Android开发工具 记得我的第一篇博客就是写Android Studio,但是现在看来还是有些粗糙了,所有重构了一下思路, ...

  10. 学生信息管理小系统(以XML为存储方式)

    为了更好地应用XML,就写了这个小项目. 下面是我的项目的目录结构 项目思路 dao是Date Access Object 数据访问层,主要是负责操作数据 domain是实体层,类似于bean层,放置 ...