扫雷C源代码
C语言扫雷游戏源代码

/*模拟扫雷游戏*/#include <graphics.h>#include <math.h>#include <stdio.h>#include <dos.h>#include <stdlib.h>#include <conio.h>#include <alloc.h>union REGS regs;int size=15;/*用于表示每个方块的大小(正方形的边长)*/int pix,piy=50;/*pix,piy是矩阵的偏移量*/char b[2]="1";/*用于显示方格周围的雷的个数*/int pan[30][16];/*用于记录盘面的情况:0:没有、9:有雷、1~8:周围雷的个数*/int pan1[30][16];/*pan1[][]纪录当前的挖雷情况,0:没有操作、1:打开了、2:标记了*/int tt;/*纪录时间参数*/int Eflags;/*用于标记鼠标按钮的有效性,0:有效,1:无效,2:这是鼠标的任意键等于重新开始*/int Msinit();void Draw(int x,int y,int sizex,int sizey);void Facedraw(int x,int y,int sizel,int k);void Dead(int sizel,int x,int y);void Setmouse(int xmax,int ymax,int x,int y);int Msread(int *xp,int *yp,int *bup,struct time t1,int k);void Draw1(int x,int y);int Open(int x,int y);float Random();void Have(int sum,int x,int y,int xx,int yy);void Help();void Coread();void Ddraw2(int x,int y);/*下面是主函数*/main(){int mode=VGAHI,devices=VGA;/*图形模式初始化的变量*/char ams; /*鼠标操作中的标志变量*/int xms,yms,bms; /*鼠标的状态变量*/int i,j,k,k1=0; /*i,j,k是循环变量*/int x=9,y=9,flags=0; /*x,y矩阵的大小*/int sum=10; /*sum 盘面的雷的总数目,是个x,y的函数*/int x1=0,y1=0; /*用于记录光标当前的位置*/int x11=0,y11=0; /*暂时保存鼠标位置的值*/int sizel=10; /*脸的大小*/int cflags=1; /*这是菜单操作标志变量,没有弹出1,弹出0*/struct time t1={0,0,0,0}; /*时间结构体,头文件已定义*/int co[3]; /*暂时纪录历史纪录*/void far *Map; /*用于保存鼠标图片*/char name[3][20]; /*名字字符串,用于记录名字*/FILE * p; /*文件指针用于文件操作*/Msinit(); /*鼠标初始化*//*registerbgidriver(EGAVGA_driver);*/initgraph(&devices,&mode,"C:\\tc"); /*图形模式初始化*//*为图片指针分配内存*/if((Map=farmalloc(imagesize(0,0,20,20)))==NULL)/*图片的大小是20*20*/{printf("Memory ererr!\n");printf("Press any key to out!\n");exit(1);}/*用于检验文件是否完整*/while((p = fopen("score.dat", "r")) == NULL) /*如果不能打开就新建一个*/{if((p = fopen("score.dat", "w")) == NULL)/*如果不能新建就提示错误并推出*/ {printf("The file cannot open!\n");printf("Presss any key to exit!\n");getch();exit(1);}/*写入初始内容*/fprintf(p,"%d %d %d,%s\n%s\n%s\n",999,999,999,"xiajia","xiajia","xiajia"); fclose(p);}/*暂时读出历史纪录。
扫雷C源代码

/*5.3.4源程序*/#include<graphics.h>//图形函数库 #include<stdlib.h>#include<dos.h> #defineLEFTPRESS0xff01//鼠标左键 #defineLEFTCLICK0xff10//左键单击 #defineLEFTDRAG0xff19#defineMOUSEMOVE0xff08struct{introundnum;/*统计格子周围有多少雷*/intflag;/*右键按下显示红旗的标志,0没有红旗标志}Mine[10][10];intgameAGAIN=0;/*是否重来的变量*/intgamePLAY=0;/*是否是第一次玩游戏的标志*/ intmineNUM;/*统计处理过的格子数*/charrandmineNUM[3];/*显示数字的字符串*/ intKeystate; intMouseExist; intMouseButton; intMouseX; intMouseY;voidInit(void);/*图形驱动*/voidMouseOn(void);/*鼠标光标显示*/ voidMouseOff(void);/*鼠标光标隐藏*/ voidMouseSetXY(int,int);/*设置当前位置*/intLeftPress(void);/*左键按下*/ intRightPress(void);/*鼠标右键按下*/ voidMouseGetXY(void);/*得到当前位置*/ voidControl(void);/*游戏开始,重新,关闭*/ voidGameBegain(void);/*游戏开始画面*/ voidDrawSmile(void);/*画笑脸*/voidDrawRedflag(int,int);/*显示红旗*/voidDrawEmpty(int,int,int,int);/*两种空格子的显示voidGameOver(void);/*游戏结束*/ voidGameWin(void);/*显示胜利*/intMineStatistics(int,int);/*统计每个格子周围的雷数 intShowWhite(int,int);/*显示无雷区的空白部分 voidGamePlay(void);/*游戏过程*/ voidClose(void);/*图形关闭*/ voidmain(void){Init(); Control(); Close();intnum;/*格子当前处于什么状态,1有雷,0已经显示过数字或者空白格*/,1有红旗标志 */*/*/*/口voidInit(void)/*图形开始*/{intgd=DETECT,gm;initgraph(&gd,&gm,"c:\\tc");}voidClose(void)/*图形关闭*/{closegraph();}voidMouseOn(void)/*鼠标光标显示*/{_AX=0x01;geninterrupt(0x33);}voidMouseOff(void)/*鼠标光标隐藏*/{_AX=0x02;geninterrupt(0x33);}voidMouseSetXY(intx,inty)/*设置当前位置*/{_CX=x;_DX=y;_AX=0x04;geninterrupt(0x33);}intLeftPress(void)/*鼠标左键按下*/{_AX=0x03;geninterrupt(0x33);return(_BX&1);}intRightPress(void)/*鼠标右键按下*/{_AX=0x03;geninterrupt(0x33);return(_BX&2);}voidMouseGetXY(void)/*得到当前位置*/{_AX=0x03;geninterrupt(0x33);MouseX=_CX;MouseY=_DX;口voidControl(void)/*游戏开始,重新,关闭*/{intgameFLAG=1;/*游戏失败后判断是否重新开始的标志*/ while(1){if(gameFLAG)/*游戏失败后没判断出重新开始或者退出游戏的话就继续判断*/{GameBegain();/*游戏初始画面*/GamePlay();/*具体游戏*/if(gameAGAIN==1)/*游戏中重新开始*/{gameAGAIN=0;continue;}}MouseOn();gameFLAG=0;if(LeftPress())/*判断是否重新开始*/{MouseGetXY();if(MouseX>280&&MouseX<300&&MouseY>65&&MouseY<85){ gameFLAG=1;continue;}}if(kbhit())/*判断是否按键退出*/ break;}MouseOff();}voidDrawSmile(void)/*口笑脸*/{setfillstyle(SOLID_FILL,YELLOW);fillellipse(290,75,10,10);setcolor(YELLOW);setfillstyle(SOLID_FILL,BLACK);/*眼睛*/fillellipse(285,75,2,2);fillellipse(295,75,2,2);setcolor(BLACK);/*嘴巴*/bar(287,80,293,81);口voidDrawRedflag(inti,intj)/*显示红旗*/{setcolor(7);setfillstyle(SOLID_FILL,RED);bar(198+j*20,95+i*20,198+j*20+5,95+i*20+5);setcolor(BLACK);line(198+j*20,95+i*20,198+j*20,95+i*20+10);}voidDrawEmpty(inti,intj,intmode,intcolor)/*两种空格子的显示*/{ setcolor(color);setfillstyle(SOLID_FILL,color);if(mode==0)/*没有单击过的大格子*/bar(200+j*20-8,100+i*20-8,200+j*20+8,100+i*20+8);elseif(mode==1)/*单击过后显示空白的小格子*/bar(200+j*20-7,100+i*20-7,200+j*20+7,100+i*20+7);}voidGameBegain(void)/*游戏开始画面*/{inti,j;cleardevice(); if(gamePLAY!=1){MouseSetXY(290,70);/*鼠标一开始的位置MouseX=290; MouseY=70; }gamePLAY=1;/*下次按重新开始的话鼠标不重新初始化mineNUM=0; setfillstyle(SOLID_FILL,7); bar(190,60,390,290);for(i=0;i<10;i++)/*画格子*/ for(j=0;j<10;j++)DrawEmpty(i,j,0,8); setcolor(7);DrawSmile();/*画脸*/randomize();for(i=0;i<10;i++)/*100个格子随机赋值有没有地雷for(j=0;j<10;j++){Mine[i][j].num=random(8);/*如果随机数的结果是if(Mine[i][j].num==1)mineNUM++;/*现有雷数加1*/elseMine[i][j].num=2;Mine[i][j].flag=0;/*表示没红旗标志 }sprintf(randmineNUM,"%d",mineNUM); */setcolor(1);settextstyle(0,0,2);outtextxy(210,70,randmineNUM);mineNUM=100-mineNUM;/*变量取空白格数量MouseOn();口voidGameOver(void)/*游戏结束画面*/{inti,j;setcolor(0); for(i=0;i<10;i++) for(j=0;j<10;j++)if(Mine[i][j].num==1)/*显示所有的地雷*/{DrawEmpty(i,j,0,RED);setfillstyle(SOLID_FILL,BLACK);fillellipse(200+j*20,100+i*20,7,7); }}voidGameWin(void)/*显示胜利*/{/*显示这次总共有多,并作为它的初始坐标*/*/*/1表示这个格子有地雷*/*/ 少雷数*/setcolor(11);settextstyle(0,0,2);outtextxy(230,30,"YOUWIN!");}intMineStatistics(inti,intj)/*统计每个格子周围的雷数*/{intnNUM=0;if(i==0&&j==0)/*左上角格子的统计*/{if(Mine[0][1].num==1)nNUM++;if(Mine[1][0].num==1)nNUM++;if(Mine[1][1].num==1)nNUM++;口elseif(i==0&&j==9)/*右上角格子的统计*/{if(Mine[0][8].num==1)nNUM++;if(Mine[1][9].num==1)nNUM++;if(Mine[1][8].num==1)nNUM++;}elseif(i==9&&j==0)/*左下角格子的统计*/{if(Mine[8][0].num==1)nNUM++;if(Mine[9][1].num==1)nNUM++;if(Mine[8][1].num==1)nNUM++;}elseif(i==9&&j==9)/*右下角格子的统计*/{if(Mine[9][8].num==1)nNUM++;if(Mine[8][9].num==1)nNUM++;if(Mine[8][8].num==1)nNUM++;}elseif(j==0)/*左边第一列格子的统计*/{if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;}elseif(j==9)/*右边第一列格子的统计*/口if(Mine[i][j-1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;}elseif(i==0)/*第一行格子的统计*/{if(Mine[i+1][j].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;}elseif(i==9)/*最后一行格子的统计*/{if(Mine[i-1][j].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;}else/*普通格子的统计*/{if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;}return(nNUM);/*把格子周围一共有多少口数的统计结果返回*/ShowWhite(inti,intj)/*显示无雷区的空白部分*/{if(Mine[i][j].flag==l||Mine[i][j].num==0)/*如果有红旗或该格处理过就不对该格进行*/return;mineNUM --;/*显示过数字或者空格的格子就表示多处理了一个格子,当所有格子都处理过了表示胜利口int 任何判断*/if(Mine[i][j].roundnum==0&&Mine[i][j].num!=1)/*显示空格*/{DrawEmpty(i,j,1,7);Mine[i][j].num=0; } elseif(Mine[i][j].roundnum!=0)/*输出口数*/{ DrawEmpty(i,j,0,8);sprintf(randmineNUM,"%d",Mine[i][j].roundnum); setcolor(RED);outtextxy(195+j*20,95+i*20,randmineNUM);Mine[i][j].num=0;/*已经输出口数的格子用0表示已经用过这个格子*/ return }/*8个方向递归显示所有的空白格子*/if(i!=0&&Mine[i-1][j].num!=1)ShowWhite(i-1,j);if(i!=0&&j!=9&&Mine[i-1][j+1].num!=1)ShowWhite(i-1,j+1); if(j!=9&&Mine[i][j+1].num!=1) if(j!=9&&i!=9&&Mine[i+1][j+1].num!=1) if(i!=9&&Mine[i+1][j].num!=1) if(i!=9&&j!=0&&Mine[i+1][j-1].num!=1)if(j!=0&&Mine[i][j-1].num!=1) if(i!=0&&j!=0&&Mine[i-1][j-1].num!=1)口voidGamePlay(void)/*游戏过程*/{inti,j,Num;/*Num 用来接收统计函数返回一个格子周围有多少地雷for(i=0;i<10;i++)for(j=0;j<10;j++)Mine[i][j].roundnum 二MineStatistics(i,j);/*统计每个格子周围有多少地雷*/while(!kbhit()){if(LeftPress())/*鼠标左键盘按下*/{ MouseGetXY();if(MouseX>280&&MouseX<300&&MouseY>65&&MouseY<85)/*重新来*/{MouseOff();gameAGAIN=1;break;}if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*当前鼠标位置格*/{j 二(MouseX-190)/20;/*x 坐标*/ i 二(MouseY-90)/20;/*y 坐标*/if(Mine[i][j].flag==1)/*如果格子有红旗则左键无效*/continue;if(Mine[i][j].num!=0)/*如果格子没有处理过*/{ShowWhite(i,j+1); ShowWhite(i+1,j+1);ShowWhite(i+1,j); ShowWhite(i+1,j-1); ShowWhite(i,j-1);*/子范if(Mine[i][j].num==1)/*鼠标按下的格子是地雷*/{MouseOff();GameOver();/*游戏失败*/break;}else/*鼠标按下的格子不是地雷*/{MouseOff();Num=MineStatistics(i,j);if(Num==0)/*周围没地雷就用递归算法来显示空白格子*/ ShowWhite(i,j);else/*按下格子周围有地雷*/{sprintf(randmineNUM,"%d",Num);/*输出当前格子周围的雷数*/setcolor(RED);outtextxy(195+j*20,95+i*20,randmineNUM);mineNUM-;}MouseOn();Mine[i][j].num=0;/*点过的格子周围雷数的数字变为0表示这个格子已经用过*/if(mineNUM<1)/*胜利了*/{GameWin();break;}}}}}if(RightPress())/*鼠标右键键盘按下*/{MouseGetXY();if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*当前鼠标位置在格范围*/{j二(MouseX-190)/20;/*x坐标*/i二(MouseY-90)/20;/*y坐标*/MouseOff();if(Mine[i][j].flag==0&&Mine[i][j].num!=0)/*本来没红旗现在显示红旗*/{DrawRedflag(i,j);Mine[i][j].flag=1;}elseif(Mine[i][j].flag==1)/*有红旗标志再按右键就红旗消失*/{DrawEmpty(i,j,0,8);Mine[i][j].flag=0;}}MouseOn();sleep(1);}}}文案大全。
c扫雷课程设计源代码

c 扫雷课程设计源代码一、教学目标本课程的目标是让学生掌握C语言编程中的扫雷游戏开发。
通过本课程的学习,学生将能够理解并运用C语言的基本语法和数据结构,编写出功能完整的扫雷游戏。
知识目标:使学生掌握C语言的基本语法、数据类型、运算符、控制结构、函数、数组和指针等知识。
技能目标:培养学生运用C语言解决实际问题的能力,学会设计并实现一个简单的扫雷游戏。
情感态度价值观目标:培养学生对计算机编程的兴趣,增强其自主学习和创新意识,使其体验到编程带来的成就感。
二、教学内容本课程的教学内容主要包括C语言的基本语法、数据类型、运算符、控制结构、函数、数组和指针等知识,以及如何运用这些知识编写扫雷游戏的源代码。
教学大纲安排如下:1.第一章:C语言基础知识,介绍C语言的基本语法、数据类型、运算符和控制结构。
2.第二章:函数与指针,讲解函数的定义和调用、指针的基本概念和运用。
3.第三章:数组与字符串,介绍数组的概念和应用、字符串的操作。
4.第四章:数据结构,讲解链表、栈和队列的基本概念及其在扫雷游戏中的应用。
5.第五章:扫雷游戏设计与实现,引导学生运用所学知识编写扫雷游戏的源代码。
三、教学方法本课程将采用讲授法、案例分析法和实验法等多种教学方法相结合的方式进行教学。
1.讲授法:用于讲解C语言的基本语法、数据类型、运算符、控制结构、函数、数组和指针等知识。
2.案例分析法:通过分析典型的扫雷游戏案例,使学生掌握数据结构在游戏开发中的应用。
3.实验法:引导学生动手编写扫雷游戏的源代码,培养其实际编程能力。
四、教学资源本课程的教学资源包括教材、参考书、多媒体资料和实验设备等。
1.教材:选用《C程序设计》等相关教材,作为学生学习的基础资源。
2.参考书:推荐《C语言深度剖析》等参考书,帮助学生深入了解C语言的内部机制。
3.多媒体资料:提供在线编程教程、扫雷游戏案例视频等,丰富学生的学习方式。
4.实验设备:为学生提供计算机、编程环境等实验设备,以便进行编程实践。
原创C语言扫雷程序大作业代码

int a;
a=srdng(x,y);
if(a!=0)
{
tru[x-1][y-1]=a;
tbl[x+1][y+1]=a;
}
else
{
tru[x-1][y-1]='O';
tbl[x+1][y+1]='O';
jdg_4(x-1,y-1);
jdg_4(x,y-1);
jdg_4(x+1,y-1);
}
return 0;
scanf("%d",&z);
if (z==3)//--------------------------------待定
{
tbl[x+1][y+1]='?';
dspl();
}
else
if(z==2)//-----------------------------标记
{
tbl[x+1][y+1]='P';
{
if((x>=1)&&(x<=10)&&(y>=1)&&(y<=10)&&(tru[x-1][y-1]='_'))
anls_1(x,y);
return 0;
}
int anls_2(int x,int y)//-------------------------------------上方境况分析(空白点的迭代)
{1,'|','_','_','_','_','_','_','_','_','_','_'},
c语言扫雷程序代码

if(n==0) {
for(i=0;i<2;i++) for(j=0;j<2;j++) { if(b[x+i][x+j]==10) { b[x+i][y+j]=0; printf_0(b,x+i,y+j); } }
} else b[x][y]=n; } else if(x==0&&y<Map_list-1&&y>0) { n=0; for(i=0;i<2;i++)
for(j=-1;j<2;j++) if(b[x+i][y+j]==11) n++;
if(n!=0) b[x][y]=n;
else for(i=0;i<2;i++)
for(j=-1;j<2;j++) {
if(b[x+i][y+j]==10) {
b[x+i][y+j]=0; printf_0(b,x+i,y+j); } } } else if(x==0&&y==Map_list-1) { n=0; for(i=0;i<2;i++) for(j=-1;j<1;j++) if(b[x+i][y+j]==11) n++; if(n!=0) b[x][y]=n; else for(i=0;i<2;i++) for(j=-1;j<1;j++) { if(b[x+i][y+j]==10) { b[x+i][y+j]=0; printf_0(b,x+i,y+j); } } } else if(y==Map_list-1&&x!=0&x!=Map_line-1) { n=0; for(i=-1;i<2;i++) for(j=-1;j<1;j++) if(b[x+i][y+j]==11) n++; if(n!=0) b[x][y]=n; else for(i=-1;i<2;i++) for(j=-1;j<1;j++) { if(b[x+i][y+j]==10) {
扫雷c语言程序设计

扫雷c语言程序设计以下是一个简单的扫雷游戏的C语言程序设计示例:c复制代码#include <stdio.h>#include <stdlib.h>#include <time.h>#define ROWS 9#define COLS 9#define MINE 10#define UNKNOWNS 0#define EMPTY 0#define MARKED 255int board[ROWS][COLS];int numMines;int numFlags;int numUnknowns;int revealed[ROWS][COLS];void initBoard() {srand(time(NULL));numMines = ROWS * COLS - 1;for (int i = 0; i < ROWS; i++) {for (int j = 0; j < COLS; j++) {board[i][j] = (rand() % (MINE + 1)) + 1; if (board[i][j] == MINE) {numMines--;} else if (rand() % 2 == 0) {board[i][j] = UNKNOWNS;numUnknowns++;} else {board[i][j] = EMPTY;}}}void reveal(int row, int col) {if (row >= 0 && row < ROWS && col >= 0 && col < COLS && board[row][col] != MARKED) { if (board[row][col] == MINE) {printf("Game over!\n");exit(0);} else if (board[row][col] == UNKNOWNS) {numUnknowns--;for (int i = 0; i < ROWS; i++) {for (int j = 0; j < COLS; j++) {if (revealed[i][j] == 0 && isSafe(i, j)) {reveal(i, j);}}} else if (board[row][col] == EMPTY) { revealed[row][col] = 1;} else {printf("You hit a mine!\n");exit(0);}}}int isSafe(int row, int col) {int count = 0;for (int i = 0; i < ROWS; i++) {for (int j = 0; j < COLS; j++) {if ((i == row && j == col) || board[i][j] ==MARKED) continue;if ((i - row) * (i - row) + (j - col) * (j - col) <= numFlags * numFlags) {count++;} else if (board[i][j] != EMPTY) {return 0; // not safe, there is a mine here.}}}return count == numFlags + 1; // safe if all adjacent cells are either mines or flags.}。
扫雷游戏源代码

int x,y,z,cc;
bool lei=false;
now_time = time(NULL);
h=now_time;
cc=c;
//初始化数组
for(int i=0;i<maxcell;i++)
for(int y=0;y<maxcell;y++)
void cell(int a,int b,int c)
{
//
time_t now_time;
time_t h;
srand( (unsigned)time( NULL ) );
initgraph((a+2)*cel,(b+5)*cel);
MOUSEMSG m;
int mimi[maxcell][maxcell];
case WM_RBUTTONDOWN:
x=m.x/cel-1;
y=m.y/cel-1;
if(mimi[x][y]==0)
{
mimi[x][y]=2;
cc--;
}
else if(mimi[x][y]==2)
{
/////////////////////////
//@挚爱
//vc6.0 EasyX库
///////////////////////////
#include<graphics.h>
#include <conio.h>
#include<time.h>
#include <stdio.h>
扫雷算法c语言

扫雷算法c语言扫雷算法的C语言实现可以有很多种,以下是一个简单的示例:```cinclude <>include <>define SIZE 10typedef struct {int mines;int numbers;int cells;} Game;void initializeGame(Game game) {game->mines = SIZE SIZE - SIZE;game->numbers = 0;game->cells = (int )malloc(SIZE SIZE sizeof(int));for (int i = 0; i < SIZE SIZE; i++) {game->cells[i] = -1;}for (int i = 0; i < SIZE; i++) {for (int j = 0; j < SIZE; j++) {if (rand() % 2 == 0) { // Place a minegame->cells[i SIZE + j] = 0;game->mines--;} else { // Place a number or a blank spacegame->cells[i SIZE + j] = rand() % 3 + 1;game->numbers++;}}}}void printGame(Game game) {for (int i = 0; i < SIZE; i++) {for (int j = 0; j < SIZE; j++) {if (game->cells[i SIZE + j] == -1) { // Blank space printf(" ");} else if (game->cells[i SIZE + j] == 0) { // Mineprintf("");} else { // Number or question markprintf("%d", game->cells[i SIZE + j]);}}printf("\n");}}void solveGame(Game game) {for (int i = 0; i < SIZE; i++) {for (int j = 0; j < SIZE; j++) {if (game->cells[i SIZE + j] == -1) { // Blank space, check surrounding cells to see if they are mines or numbersif (i > 0 && game->cells[(i - 1) SIZE + j] != 0 && game->cells[(i - 1) SIZE + j] != game->cells[i SIZE + j]) { // Check above cellgame->cells[i SIZE + j] = game->cells[(i - 1) SIZE + j]; // Set this cell to the same value as the above cell (mine or number)} else if (i < SIZE - 1 && game->cells[(i + 1) SIZE + j] != 0 && game->cells[(i + 1) SIZE + j] != game->cells[i SIZE + j]) { // Check below cellgame->cells[i SIZE + j] = game->cells[(i + 1) SIZE + j]; // Set this cell to the same value as the below cell (mine or number) } else if (j > 0 && game->cells[i SIZE + (j - 1)] != 0 && game->cells[i SIZE + (j - 1)] != game->cells[i SIZE + j]) { // Check left cellgame->cells[i SIZE + j] = game->cells[i SIZE + (j - 1)]; // Set this cell to the same value as the left cell (mine or number)} else if (j < SIZE - 1 && game->cells[i SIZE + (j + 1)] != 0 && game->cells[i SIZE + (j + 1)] != game->cells[i SIZE + j]) { // Check right cellgame->cells[i SIZE + j] = game->cells[i SIZE + (j + 1)]; // Set this cell to the same value as the right cell (mine or number)} else if (game->numbers > 0) { // If there are still numbers in the game, place a number here if it's a blank space, and reduce the number of numbers by one. Otherwise, place a mine and reduce the number of mines by one.game->cells[i SIZE + j] = rand() % 3 + 1; // Place a number here if it's a blank space, and reduce the number。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
/*5.3.4源程序*/ #include<>um=random(8);/*如果随机数的结果是1表示这个格子有地雷*/if(Mine[i][j].num==1)mineNUM++;/*现有雷数加1*/elseMine[i][j].num=2;Mine[i][j].flag=0;/*表示没红旗标志*/}sprintf(randmineNUM,"%d",mineNUM);/*显示这次总共有多少雷数*/setcolor(1);settextstyle(0,0,2);outtextxy(210,70,randmineNUM);mineNUM=100-mineNUM;/*变量取空白格数量*/MouseOn();}voidGameOver(void)/*游戏结束画面*/{inti,j;setcolor(0);for(i=0;i<10;i++)for(j=0;j<10;j++)if(Mine[i][j].num==1)/*显示所有的地雷*/{DrawEmpty(i,j,0,RED);setfillstyle(SOLID_FILL,BLACK);fillellipse(200+j*20,100+i*20,7,7);}}voidGameWin(void)/*显示胜利*/{setcolor(11);settextstyle(0,0,2);outtextxy(230,30,"YOUWIN!");}intMineStatistics(inti,intj)/*统计每个格子周围的雷数*/{ intnNUM=0;if(i==0&&j==0)/*左上角格子的统计*/{if(Mine[0][1].num==1)nNUM++;if(Mine[1][0].num==1)nNUM++;if(Mine[1][1].num==1)nNUM++;}elseif(i==0&&j==9)/*右上角格子的统计*/{if(Mine[0][8].num==1)nNUM++;if(Mine[1][9].num==1)nNUM++;if(Mine[1][8].num==1)nNUM++;}elseif(i==9&&j==0)/*左下角格子的统计*/{if(Mine[8][0].num==1)nNUM++;if(Mine[9][1].num==1)nNUM++;if(Mine[8][1].num==1)nNUM++;}elseif(i==9&&j==9)/*右下角格子的统计*/{if(Mine[9][8].num==1)nNUM++;if(Mine[8][9].num==1)nNUM++;if(Mine[8][8].num==1)nNUM++;}elseif(j==0)/*左边第一列格子的统计*/{ if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++; if(Mine[i+1][j+1].num==1)nNUM++;}elseif(j==9)/*右边第一列格子的统计*/{if(Mine[i][j-1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;}elseif(i==0)/*第一行格子的统计*/{if(Mine[i+1][j].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;}elseif(i==9)/*最后一行格子的统计*/{ if(Mine[i-1][j].num==1)nNUM++; if(Mine[i][j-1].num==1)nNUM++; if(Mine[i][j+1].num==1)nNUM++; if(Mine[i-1][j-1].num==1)nNUM++; if(Mine[i-1][j+1].num==1)nNUM++;}else/*普通格子的统计*/{if(Mine[i-1][j].num==1)nNUM++;if(Mine[i-1][j+1].num==1)nNUM++;if(Mine[i][j+1].num==1)nNUM++;if(Mine[i+1][j+1].num==1)nNUM++;if(Mine[i+1][j].num==1)nNUM++;if(Mine[i+1][j-1].num==1)nNUM++;if(Mine[i][j-1].num==1)nNUM++;if(Mine[i-1][j-1].num==1)nNUM++;}return(nNUM);/*把格子周围一共有多少雷数的统计结果返回*/}intShowWhite(inti,intj)/*显示无雷区的空白部分*/{if(Mine[i][j].flag==1||Mine[i][j].num==0)/*如果有红旗或该格处理过就不对该格进行任何判断*/return;mineNUM--;/*显示过数字或者空格的格子就表示多处理了一个格子,当所有格子都处理过了表示*/if(Mine[i][j].roundnum==0&&Mine[i][j].num!=1)/*显示空格*/{DrawEmpty(i,j,1,7);Mine[i][j].num=0;}elseif(Mine[i][j].roundnum!=0)/*输出雷数*/{DrawEmpty(i,j,0,8);sprintf(randmineNUM,"%d",Mine[i][j].roundnum);setcolor(RED);outtextxy(195+j*20,95+i*20,randmineNUM);Mine[i][j].num=0;/*已经输出雷数的格子用0表示已经用过这个格子*/ return}/*8个方向递归显示所有的空白格子*/if(i!=0&&Mine[i-1][j].num!=1)ShowWhite(i-1,j);if(i!=0&&j!=9&&Mine[i-1][j+1].num!=1)ShowWhite(i-1,j+1);if(j!=9&&Mine[i][j+1].num!=1)ShowWhite(i,j+1);if(j!=9&&i!=9&&Mine[i+1][j+1].num!=1)ShowWhite(i+1,j+1);if(i!=9&&Mine[i+1][j].num!=1)ShowWhite(i+1,j);if(i!=9&&j!=0&&Mine[i+1][j-1].num!=1)ShowWhite(i+1,j-1);if(j!=0&&Mine[i][j-1].num!=1)ShowWhite(i,j-1);if(i!=0&&j!=0&&Mine[i-1][j-1].num!=1)ShowWhite(i-1,j-1);}voidGamePlay(void)/*游戏过程*/{inti,j,Num;/*Num用来接收统计函数返回一个格子周围有多少地雷*/ for(i=0;i<10;i++)for(j=0;j<10;j++)Mine[i][j].roundnum=MineStatistics(i,j);/*统计每个格子周围有多少地雷*/while(!kbhit()){if(LeftPress())/*鼠标左键盘按下*/{MouseGetXY();if(MouseX>280&&MouseX<300&&MouseY>65&&MouseY<85)/*重新来*/{MouseOff();gameAGAIN=1;break;}if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*当前鼠标位置格子范围内*/ j=(MouseX-190)/20;/*x坐标*/i=(MouseY-90)/20;/*y坐标*/if(Mine[i][j].flag==1)/*如果格子有红旗则左键无效*/continue;if(Mine[i][j].num!=0)/*如果格子没有处理过*/{if(Mine[i][j].num==1)/*鼠标按下的格子是地雷*/{MouseOff();GameOver();/*游戏失败*/break;}else/*鼠标按下的格子不是地雷*/{MouseOff();Num=MineStatistics(i,j);if(Num==0)/*周围没地雷就用递归算法来显示空白格子*/ShowWhite(i,j);else/*按下格子周围有地雷*/{sprintf(randmineNUM,"%d",Num);/*输出当前格子周围的雷数*/setcolor(RED);outtextxy(195+j*20,95+i*20,randmineNUM);mineNUM--;}MouseOn();Mine[i][j].num=0;/*点过的格子周围雷数的数字变为0表示这个格子已经用过*/ if(mineNUM<1)/*胜利了*/{GameWin();break;}}}}}if(RightPress())/*鼠标右键键盘按下*/{MouseGetXY();if(MouseX>190&&MouseX<390&&MouseY>90&&MouseY<290)/*当前鼠标位置在格范围内*/{ j=(MouseX-190)/20;/*x坐标*/i=(MouseY-90)/20;/*y坐标*/MouseOff();if(Mine[i][j].flag==0&&Mine[i][j].num!=0)/*本来没红旗现在显示红旗*/{ DrawRedflag(i,j);Mine[i][j].flag=1;}elseif(Mine[i][j].flag==1)/*有红旗标志再按右键就红旗消失*/{DrawEmpty(i,j,0,8);Mine[i][j].flag=0;}}MouseOn();sleep(1);}}}。