扫雷

原创 2018年04月15日 10:36:01
#ifndef  __GAME_H__
#define  __GAME_H__


#define ROWS 12
#define COLS 12
#define M 10


void init_board(char board[ROWS][COLS],int rows,int cols,char ch);
void lay_mine(char board[ROWS][COLS],int rows,int cols,int m);
void dis_play(char board[ROWS][COLS],int rows,int clos);
void one_input(char board1[ROWS][COLS],int x,int y,int count);
int mine_count(char board1[ROWS][COLS],char board2[ROWS][COLS],int x,int y);
int check_win(char board[ROWS][COLS],int rows,int clos);


#endif//__GAME_H__
void init_board(char board[ROWS][COLS],int rows,int cols,char ch)    
{
    int i = 0;
    int j = 0;
    for(i = 0;i < rows;i++)
    {
        for(j = 0;j < cols;j++)    
        {
            board[i][j] = ch;
        }
    }
}
void lay_mine(char board[ROWS][COLS],int rows,int cols,int m)   
{
    int i = 0;
    while(i<m)
    {
        while(1)
        {
        int x = (rand()%(ROWS-2))+1;
        int y = (rand()%(COLS-2))+1;
        if(board[x][y] != '1')
        {
            board[x][y] = '1';
            break;
        }
        }
        i++;
    }
}
void dis_play(char board[ROWS][COLS],int rows,int clos)    
{
    int i = 0;
    int j = 0;
    printf("   ");
    for(i = 1;i<rows-1;i++)
    {
        printf("%3d",i);
    }
    printf("\n");
    for(i = 0;i<rows-1;i++)
    {
        printf("---");
    }
    printf("\n");
    for(i = 1;i < rows-1;i++)
    {
        printf("%2d|",i);
        for(j = 1;j < clos-1;j++)
        {
            printf("%3c",board[i][j]);
        }
        printf("\n");
    }
}
nt mine_count(char board1[ROWS][COLS],char board2[ROWS][COLS],int x,int y)     //周围雷的个数
{
    if(board1[x][y] == '1')                 //踩到雷,返回‘b’
    {
        board2[x][y] = '1';
        return 'b';
    }
    if(board1[x][y] == '0')
    {


        board2[x][y] = (board1[x-1][y-1] + board1[x-1][y] + board1[x-1][y+1] + 
                        board1[x][y-1]   + board1[x][y+1] + 
                        board1[x+1][y-1] + board1[x+1][y] + board1[x+1][y+1]) - (7*48) ;
    }
    return 1;
}
int check_win(char board1[ROWS][COLS],int rows,int cols)                 
{
    int i = 0;
    int j = 0;
    int m = 0;
    for(i = 1;i <rows-1; i++)
    {
        for(j = 1;j <cols-1;j++)
        {
            if(board1[i][j] != '*')
            {
                m++;
            }
        }
    }
    if(m == (100-M))
    {
        return 'n';
    }


    return 1;
}
#include"game.h"
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void menu()
{
    printf("******************************\n");
    printf("*****  1.paly    2.exit   ****\n");
    printf("******************************\n");
}
void game()
{
    int count = 0;
    int ret = 0;
    int x = 0;
    int y = 0;
    char mine[ROWS][COLS] ;
    char show[ROWS][COLS] ;
    init_board(mine,ROWS,COLS,'0'); 
    init_board(show,ROWS,COLS,'*');
    lay_mine(mine,ROWS,COLS,M);
    dis_play(show,ROWS,COLS);
    dis_play(mine,ROWS,COLS);


    while(1)
    {
        printf("请输入坐标:");
        while(1)
        {
           scanf("%d %d",&x,&y); 
           if(((x>10)||(x<1))||((y>10)||(y<1)))
           {
              printf("输入坐标有误,请重新输入!\n");
           }
           else
           {
              count++;
              break;
           }
       }


       one_input(mine,x,y,count);              //第一次踩到雷不炸
       //dis_play(mine,ROWS,COLS);
       ret = mine_count(mine,show,x,y);
       if(ret =='b')
       {
          break;
       }
       dis_play(show,ROWS,COLS);
       ret = check_win(show,ROWS,COLS);
       if(ret == 'n')
       {
           break;
       }


    }
    if(ret == 'b')
    {
        printf("很遗憾,你被炸死了!\n");
    }
    if(ret == 'n')
    {
        printf("恭喜你,扫雷成功!\n");
    }
}


int main()
{
    int input = 0;
    srand((unsigned)time(NULL));
    while(1)
    {
    menu();
    printf("请选择:");
    scanf("%d",&input);
    switch(input)
    {
    case 1:
        game();
        break;
    case 2:
        return 0;
        break;
    default:
        printf("选择错误,请重新选择:");
        break;
    }
    }
    system("pause");
    return 0;
}

扫雷图片资源

  • 2014年01月15日 16:32
  • 8KB
  • 下载

扫雷 源码 源代码 java

  • 2010年08月11日 09:46
  • 102KB
  • 下载

Unity实现简易扫雷

扫雷的核心思想就是递归,点击一个格子,四周八个格子都会进行检测雷的操作,直到不能检测,用的是广度搜索算法。因为不想写太长的博客,技术也有限,所以这是个简易的扫雷,可扩展性也不好,大家看看思想就好,有兴...
  • zzw8866755
  • zzw8866755
  • 2016-09-29 19:25:24
  • 1301

Web版 扫雷 JS实现

这几天中毒了,无比迷恋扫雷游戏(摔!明明是机房机器渣到只能玩扫雷),于是在上网络互联与路由课的时候,写了个Web版的扫雷游戏,起码能玩了,嘿嘿,晚上又增加了一些有趣的东东,还有个彩蛋。DEMO:htt...
  • Jesounao
  • Jesounao
  • 2016-05-26 11:03:55
  • 3055

可联网的扫雷游戏

  • 2008年06月04日 12:50
  • 68KB
  • 下载

java 扫雷游戏源码案例项目

代码如下 import java.awt.*; import javax.swing.*; //图形计数器JCounter三位 class JCounter extends JPanel { ...
  • guangxiaove
  • guangxiaove
  • 2015-02-03 09:59:08
  • 8734

Qt扫雷游戏

Qt扫雷游戏最近在学习Qt,于是想到将以前VS2013上写过的扫雷程序移植到Qt上.当时是模仿Window XP上自带的扫雷游戏写的,水平有限,代码写的比较水.现在把它移植到Qt平台上,实现了扫雷最基...
  • u013407923
  • u013407923
  • 2016-01-07 00:23:59
  • 3227

扫雷(HTML+JS+CSS)

  • 2013年03月13日 10:19
  • 3.59MB
  • 下载

简单扫雷游戏中的编程方法学 - python实现

一、说明 该题来自国外大学的一个课堂作业,需求文档中要求采用一种自底向上(bottom-up)的编程方法,先实现最基本的函数,然后编写高层一点的函数来调用这些基本函数,先细节再慢慢抽象。为了引导学生,...
  • heyabo
  • heyabo
  • 2014-04-20 16:50:40
  • 3968

Unity制作扫雷游戏

曾经在网上看了一篇扫雷教程,链接如下:https://noobtuts.com/unity/2d-minesweeper-game 但是照着做出来有点问题,后来自己尝试的做了一个,效果如图: ...
  • HeBiReChenAi
  • HeBiReChenAi
  • 2016-12-23 10:41:06
  • 1715
收藏助手
不良信息举报
您举报文章:扫雷
举报原因:
原因补充:

(最多只允许输入30个字)