C++实现扫雷小游戏

本文实例为大家分享了C++实现扫雷游戏的具体代码,供大家参考,具体内容如下

#include<stdio.h>
#include<windows.h>
#include<stdlib.h>
#include<time.h>
#include<conio.h>
#include<queue>
#include<ctype.h>
#define A 17 //地图的高
#define B 17 //地图的宽
#define C 30 //雷的总数
using namespace std;

//全局变量
DWORD a,b;
char map[A][B],news,spare;
int BoomTotalNum,floatx,floaty,flag[A][B],flagnum,mode,slect[A][B],game;

//颜色属性
const WORD FORE_BLUE = FOREGROUND_BLUE; //蓝色文本属性
const WORD FORE_GREEN = FOREGROUND_GREEN; //绿色文本属性
const WORD FORE_RED  =  FOREGROUND_RED; //红色文本属性

//开垦地图结构体
struct node {
 int x;
 int y;
};
queue <node> dui;

//打印位置
void position(int x,int y) {
 COORD pos={x,y};
 HANDLE Out=GetStdHandle(STD_OUTPUT_HANDLE);
 SetConsoleCursorPosition(Out,pos);
}

//隐藏光标
void Hide() {
 HANDLE handle = GetStdHandle(STD_OUTPUT_HANDLE);
 CONSOLE_CURSOR_INFO CursorInfo;
 GetConsoleCursorInfo(handle, &CursorInfo);//获取控制台光标信息
 CursorInfo.bVisible = false; //隐藏控制台光标
 SetConsoleCursorInfo(handle, &CursorInfo);//设置控制台光标状态
}

//初始化
void Beginning() {
 while(!dui.empty()) {
 dui.pop();
 }
 game=1;
 //BoomTotalNum=C;
 floatx=A/2;
 floaty=B/2;
 flagnum=0;
 BoomTotalNum=C;
 mode=0;
 HANDLE handle_out = GetStdHandle(STD_OUTPUT_HANDLE);  //获得标准输出设备句柄
  CONSOLE_SCREEN_BUFFER_INFO csbi;            //定义窗口缓冲区信息结构体
  GetConsoleScreenBufferInfo(handle_out, &csbi);     //获得窗口缓冲区信息
  int x,y;
 srand((unsigned)time(0));
 for(int i=0;i<A;i++) for(int j=0;j<B;j++) {
 map[i][j]=' ';
 flag[i][j]=0;
 slect[i][j]=0;
 }
 while(BoomTotalNum) {
 x=rand()%A;
 y=rand()%B;
 if(map[x][y]==' ') {
  map[x][y]='@';
  BoomTotalNum--;
 }
 }
 SetConsoleTextAttribute(handle_out, FORE_GREEN);
 for(int i=0;i<A;i++) {
 for(int j=0;j<B;j++) printf("█");
 printf("\n");
 }
 position(floaty*2,floatx);
 SetConsoleTextAttribute(handle_out, FORE_RED);
 printf(""); //光标位置
 position(44,9);
 printf("扫雷模式");
 position(44,5);
 printf("剩余雷数:%d ",C-flagnum);
 SetConsoleTextAttribute(handle_out, FORE_GREEN);
 position(5,22);
 printf("按“空格”切换模式");
 position(5,23);
 printf("按“Enter”确认");
 position(5,24);
 printf("按“方向键”选择方块"); 

}

//打印地图的一块儿
void Lump(int xx,int yy) {
 switch(map[xx][yy]) {
 case '1' : printf("①");break; //周围雷的数量(下同)
 case '2' : printf("②");break;
 case '3' : printf("③");break;
 case '4' : printf("④");break;
 case '5' : printf("⑤");break;
 case '6' : printf("⑥");break;
 case '7' : printf("⑦");break;
 case '8' : printf("⑧");break;
 case ' ' :
  if(xx==floatx&&yy==floaty) {
  if(flag[xx][yy]==0) {
   if(mode%2==0) printf("");
   else printf("");
  }
  else printf("");
  }
  else {
  if(flag[xx][yy]==0) printf("█");
  else printf("");
  }
  break;
 case '@' :
  if(xx==floatx&&yy==floaty) {
  if(flag[xx][yy]==0) {
   if(mode%2==0) printf("");
   else printf("");
  }
  else printf("");
  }
  else {
  if(flag[xx][yy]==0) printf("█");
  else printf("");
  }
  break;
 case 'x' : if(floatx==xx&&floaty==yy) printf(""); else printf(" ");break; //已经挖开的空白
 }
}

//移动光标
void Move() {
 HANDLE handle_out = GetStdHandle(STD_OUTPUT_HANDLE);  //获得标准输出设备句柄
  CONSOLE_SCREEN_BUFFER_INFO csbi;            //定义窗口缓冲区信息结构体
  GetConsoleScreenBufferInfo(handle_out, &csbi);     //获得窗口缓冲区信息
  int xxx,yyy;
  xxx=floatx;
  yyy=floaty;
 switch(news) {
 case 72 : floatx--;break; //上
 case 80 : floatx++;break; //下
 case 75 : floaty--;break; //左
 case 77 : floaty++;break; //右
 }
 if(floatx==-1) floatx=A-1; floatx%=A; //两端穿模处理
 if(floaty==-1) floaty=B-1; floaty%=B;

 position(yyy*2,xxx);
 SetConsoleTextAttribute(handle_out, FORE_GREEN);
 Lump(xxx,yyy); //删除原位置

 if(map[floatx][floaty]=='x') {
 position(floaty*2,floatx);
 printf(" ");
 }

 position(floaty*2,floatx);
 SetConsoleTextAttribute(handle_out, FORE_BLUE);
 Lump(floatx,floaty); //更新新位置
} 

//插旗和排雷模式切换
void Mode() {
 HANDLE handle_out = GetStdHandle(STD_OUTPUT_HANDLE);  //获得标准输出设备句柄
  CONSOLE_SCREEN_BUFFER_INFO csbi;            //定义窗口缓冲区信息结构体
  GetConsoleScreenBufferInfo(handle_out, &csbi);     //获得窗口缓冲区信息
 mode++;
 SetConsoleTextAttribute(handle_out, FORE_BLUE);
 position(floaty*2,floatx);
 if(mode%2==0) printf("");
 else printf("");

 position(44,9);
 if(mode%2==0) {
 SetConsoleTextAttribute(handle_out, FORE_BLUE);
 printf("扫雷模式");
 }
 else {
 SetConsoleTextAttribute(handle_out, FORE_RED);
 printf("插旗模式");
 }
}

//该点周围地雷数
int Boomnum(int xx,int yy) {
 int num=0;
 if((xx-1>=0)&&(yy-1>=0)&&(map[xx-1][yy-1]=='@')) num++;
 if((xx-1>=0)&&(yy+0>=0)&&(map[xx-1][yy]=='@')) num++;
 if((xx-1>=0)&&(yy+1<B) &&(map[xx-1][yy+1]=='@')) num++;
 if((xx+0>=0)&&(yy-1>=0)&&(map[xx][yy-1]=='@')) num++;
 if((xx+0>=0)&&(yy+1<B) &&(map[xx][yy+1]=='@')) num++;
 if((xx+1<A)&&(yy-1>=0) &&(map[xx+1][yy-1]=='@')) num++;
 if((xx+1<A)&&(yy+0>=0) &&(map[xx+1][yy]=='@')) num++;
 if((xx+1<A)&&(yy+1<B) &&(map[xx+1][yy+1]=='@')) num++;
 return num;
}

//更新地图
void Open() {
 node c;
 node d;
 while(!dui.empty()) {
 dui.pop();
 }
 c.x=floatx;
 c.y=floaty;
 dui.push(c);
 slect[c.x][c.y]=1;
 while(!dui.empty()) {
 c=dui.front();
 dui.pop();
 if(Boomnum(c.x,c.y)!=0) {
  map[c.x][c.y]=(Boomnum(c.x,c.y)+48);
  continue;
 }
 else {
  map[c.x][c.y]='x';
  if((c.x-1>=0)&&(c.y-1>=0)&&(map[c.x-1][c.y-1]==' ')&&(slect[c.x-1][c.y-1]==0)) {
  d.x=c.x-1;
  d.y=c.y-1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x-1>=0)&&(c.y-0>=0)&&(map[c.x-1][c.y]==' ')&&(slect[c.x-1][c.y]==0)) {
  d.x=c.x-1;
  d.y=c.y-0;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x-1>=0)&&(c.y+1<B)&&(map[c.x-1][c.y+1]==' ')&&(slect[c.x-1][c.y+1]==0)) {
  d.x=c.x-1;
  d.y=c.y+1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x-0>=0)&&(c.y-1>=0)&&(map[c.x][c.y-1]==' ')&&(slect[c.x][c.y-1]==0)) {
  d.x=c.x-0;
  d.y=c.y-1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x-0>=0)&&(c.y+1<B)&&(map[c.x][c.y+1]==' ')&&(slect[c.x][c.y+1]==0)) {
  d.x=c.x-0;
  d.y=c.y+1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x+1<A)&&(c.y-1>=0)&&(map[c.x+1][c.y-1]==' ')&&(slect[c.x+1][c.y-1]==0)) {
  d.x=c.x+1;
  d.y=c.y-1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x+1<A)&&(c.y-0>=0)&&(map[c.x+1][c.y]==' ')&&(slect[c.x+1][c.y]==0)) {
  d.x=c.x+1;
  d.y=c.y-0;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
  if((c.x+1<A)&&(c.y+1<B)&&(map[c.x+1][c.y+1]==' ')&&(slect[c.x+1][c.y+1]==0)) {
  d.x=c.x+1;
  d.y=c.y+1;
  dui.push(d);
  slect[d.x][d.y]=1;
  }
 }
 }
}

int main() {
 freopen("排名.txt","r",stdin);
 Relife: //重玩处
 HANDLE handle_out = GetStdHandle(STD_OUTPUT_HANDLE);  //获得标准输出设备句柄
  CONSOLE_SCREEN_BUFFER_INFO csbi;            //定义窗口缓冲区信息结构体
  GetConsoleScreenBufferInfo(handle_out, &csbi);     //获得窗口缓冲区信息

 Hide();
 Beginning();
 a=GetTickCount();
 while(1) {
 if(kbhit()!=0) {
  spare=getch();

  if((spare!=(-32))&&(spare!=13)&&(spare!=' ')) continue;

  if(spare==13) {;

  if(mode%2==0) {
   if(map[floatx][floaty]=='@'&&flag[floatx][floaty]==0) {
   break;
   game=0;
   }

   if(flag[floatx][floaty]==1) continue;
   Open();
   position(0,0);
   SetConsoleTextAttribute(handle_out, FORE_GREEN);
   for(int i=0;i<A;i++) {
   for(int j=0;j<B;j++) Lump(i,j);
   printf("\n");
   }
   position(floaty*2,floatx);
   SetConsoleTextAttribute(handle_out, FORE_BLUE);
   Lump(floatx,floaty);
  }

  else {

   if(map[floatx][floaty]=='x'||(map[floatx][floaty]>'0'&&map[floatx][floaty]<'9'))
   continue; 

   if(flag[floatx][floaty]==0) {
   flagnum++;
   flag[floatx][floaty]=1;
   position(floaty*2,floatx);
   SetConsoleTextAttribute(handle_out, FORE_BLUE);
   Lump(floatx,floaty);
   }

   else {
   flagnum--;
   flag[floatx][floaty]=0;
   position(floaty*2,floatx);
   SetConsoleTextAttribute(handle_out, FORE_BLUE);
   Lump(floatx,floaty);
   }
  }
  }

  if(spare==' ') Mode(); 

  //按方向键
  if(spare==-32) {
  news=getch();
  Move();
  }
  for(int i=0;i<A;i++) for(int j=0;j<B;j++) if(map[i][j]=='x'||(map[i][j]>'0'&&map[i][j]<'9')) game++;
  if(game==A*B-C+1) break;
  else game=1;
  SetConsoleTextAttribute(handle_out, FORE_RED);
  position(44,5);
  printf("剩余雷数:%d ",C-flagnum);
 }
 else Sleep(10);
 b=GetTickCount();
 SetConsoleTextAttribute(handle_out, FORE_RED);
 position(44,7);
 printf("用时:");
 if((b-a)/60000<10) printf("0");
 printf("%d:",(b-a)/60000);
 if(((b-a)/1000)%60<10) printf("0");
 printf("%d:",((b-a)/1000)%60);
 if(((b-a)/10)%100<10) printf("0");
 printf("%d",((b-a)/10)%100);
 }
 SetConsoleTextAttribute(handle_out, FORE_RED);
 position(5,5);
 if(game==1) printf("游戏结束!");
 else printf("恭喜通关!");
 position(5,8);
 printf("任意键重玩");
 scanf("%c%c",&spare,&spare);
 system("cls");
 position(0,0);
 goto Relife;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C++实现简单的扫雷游戏(控制台版)

    C++新手的代码,请各位多包涵. 用C++写的一个简单的控制台版扫雷游戏.玩家通过输入方块的坐标来翻开方块. 只是一个雏形,能够让玩家执行翻开方块的操作并且判断输赢,还未添加标记方块.游戏菜单.记录游戏时间.重新开一局等等的功能. 玩家输入坐标的方式来翻开方块只适用于小型的"雷区",若"雷区"大了,用坐标会变得很不方便. 代码片段扫雷V1.1 #include<stdio.h> #include<Windows.h> #define YELL

  • C++实现扫雷游戏

    本文实例为大家分享了C++实现扫雷游戏的具体代码,供大家参考,具体内容如下 直接上代码 #include<stdio.h> #include<windows.h> #include<stdlib.h> #include<time.h> #include<conio.h> #include<queue> #include<ctype.h> #define A 17 //地图的高 #define B 17 //地图的宽 #de

  • C++实现简单扫雷游戏

    扫雷是一个经典的电脑小游戏,用C++来编一下,效果自己试一下 #include<stdio.h> #include<Windows.h> #define YELLOW FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_INTENSITY #define CYAN FOREGROUND_BLUE | FOREGROUND_GREEN | FOREGROUND_INTENSITY #define ORANGE FOREGROUND_RED |

  • C++基于EasyX实现简单扫雷游戏

    本文实例为大家分享了C++ EasyX实现简单扫雷游戏的具体代码,供大家参考,具体内容如下 [实现代码] #include <cmath> #include <time.h> #include <easyx.h> #include <conio.h> using namespace std; #define Size 500 //定义窗口大小 #define SquareSize 50 //定义格子大小 #define BackGroundColor LIG

  • 利用c++和easyx图形库做一个低配版扫雷游戏

    游戏界面 由于这个游戏是我抱着玩一玩的心态做出来的,所以没有过多的去设计界面,也没有去找游戏的资源(图片.游戏音效等).仅使用了不同颜色的方块来表示游戏中方块的状态和种类.(绿色为初始状态(未翻转的状态),黄色为翻转后的背景颜色,蓝色表示已插旗的方块,红色代表地雷) 图1 游戏主菜单界面 图二 模式一的游戏界面(20*20 40个雷) 图三 模式二的游戏界面(10*10 20个雷) 图四 游戏成功界面 图五 游戏失败界面 2.全部代码 #include<graphics.h> #include

  • 分享自己用JS做的扫雷小游戏

    引用了jQuery,节省了很多鼠标点击上的判断.界面显然都是照搬Windows的扫雷啦,详细的内容注释里都有,我就不啰嗦啦~ 先上截图~ 引用了jQuery,节省了很多鼠标点击上的判断 界面显然都是照搬Windows的扫雷啦 详细的内容注释里都有,我就不啰嗦啦~ JS部分 var mineArray, //地雷数组 lastNum, //剩余雷数 countNum, //未被揭开的方块数 inGame = 0, //游戏状态,0为结束,1为进行中,2为初始化完毕但未开始 startTime; /

  • Android 实现扫雷小游戏实例代码

    Android 实现扫雷小游戏实例 最近学习Android 应用编程,抽空做个小应用,大家熟悉的扫雷应用,练手用, 以下是实现代码: MainActivity 类 public class MainActivity extends Activity implements OnClickListener, OnLongClickListener { // 最外层布局 LinearLayout textviews; LinearLayout buttons; int[][] map = new in

  • HTML+JavaScript实现扫雷小游戏

    本文实例为大家分享了JavaScript实现扫雷小游戏的具体代码,供大家参考,具体内容如下 工具:Sublime Text / Dreamweaver /Hbuilder <!doctype html> <html> <head> <meta charset="utf-8"> <title>SaoLei</title> <style type="text/css"> table {

  • C语言实现简单扫雷小游戏

    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <windows.h> #include <time.h> /* 用 C 语言写一个简单的扫雷游戏 */ // 1.写一个游戏菜单 Menu() // 2.开始游戏 // 1.初始化二维数组 Init_Interface() // 2.打印游戏界面 Print_Interfa

  • java实现扫雷小游戏

    本文实例为大家分享了java实现扫雷小游戏的具体代码,供大家参考,具体内容如下 代码: package GUI; import java.util.Random; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.awt.BorderLayout; import java.awt.GridLayo

  • C语言代码实现扫雷小游戏

    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 主页面: 游戏页面: 虽然页面比较low,但我已经尽力了 具体代码实现: #include<stdio.h> #include<windows.h> #include<conio.h> #include<stdlib.h> #include<time.h> int n;//记录已经探索的区域数 int x,y;//光标的横纵坐标 int T;//判断游戏是否失败,T=1

  • js+canvas实现简单扫雷小游戏

    扫雷小游戏作为windows自带的一个小游戏,受到很多人的喜爱,今天我们就来尝试使用h5的canvas结合js来实现这个小游戏. 要写游戏,首先要明确游戏的规则,扫雷游戏是一个用鼠标操作的游戏,通过点击方块,根据方块的数字推算雷的位置,标记出所有的雷,打开所有的方块,即游戏成功,若点错雷的位置或标记雷错误,则游戏失败. 具体的游戏操作如下 1.可以通过鼠标左键打开隐藏的方块,打开后若不是雷,则会向四个方向扩展 2.可以通过鼠标右键点击未打开的方块来标记雷,第二次点击取消标记 3.可以通过鼠标右键

  • C++实现一个扫雷小游戏

    本文实例为大家分享了C++实现扫雷小游戏的具体代码,供大家参考,具体内容如下 目前的版本是0.98版本,可以提出增加新功能意见哦 代码如下: #include<bits/stdc++.h> #include<windows.h> using namespace std; long long int c,dev,m,k,cnt,d,e,jie=10,z,abc,n,b[1000][1000],a[1000][1000],cc,cd,ce,def; //c是随机行,k是随机列 bool

  • C++实现扫雷小游戏(控制台版)

    本文为大家分享了C++实现扫雷小游戏的具体代码,供大家参考,具体内容如下 程序功能: 提供三种模式:初级.中级.高级 操作模式:wsad控制光标移动,空格键打开方块 提供扫雷地图的类 map.h #ifndef MAP_H_ #define MAP_H_ #define MAX_LENGTH 32 //可以提供的地图最大长度 #define MAX_WIDTH 18 //可以提供的地图最大宽度 #define UP_EDGE 1 //上边界 #define DOWN_EDGE _wid //下边

  • C语言实现扫雷小游戏(适合初学者)

    扫雷小游戏作为初学c语言的小白有很大的帮助,其中用到了函数的定义,函数的声明,循环语句,数组思想等等知识,对于代码理解和设计代码思路有很大的帮助,本文就详细介绍了代码的各个步骤和运行结果.希望给到和我一样的小白一点帮助. //game.h头文件 #include<stdio.h> #include<stdlib.h> #include<time.h> #define ROW 9//定义了界面的长宽,可以直更改ROW,COL的值,避免了程序中数字重复出现 #define

随机推荐