当前位置:主页 > c/c++教程 > C语言扫雷游戏

C语言实现扫雷小游戏的示例代码

发布:2023-03-06 09:00:01 59


为找教程的网友们整理了相关的编程文章,网友文阳炎根据主题投稿了本篇教程内容,涉及到C语言扫雷游戏、C语言、扫雷、C语言、游戏、C语言扫雷游戏相关内容,已被775网友关注,涉猎到的知识点内容可以在下方电子书获得。

C语言扫雷游戏

一、扫雷

扫雷小游戏主要是利用字符数组、循环语句和函数实现。

设计思路:雷盘大小为9*9,但是为了后续能更好的统计出雷的个数在定义数组的时候定义大小为11*11,先定义两个字符数组,一个用来记录雷的位置,另一个用来展现给玩家,初始化雷盘,将两个字符数组分别全部赋值为字符0和字符*,打印棋盘,随机设置雷所在位置,根据玩家输入的坐标排查上下左右8个格子中的雷,并判断输入坐标处是否有雷。

玩法:玩家选择开始游戏之后,输入坐标,如果坐标处有雷,输入坐标处标记为$,并打印出来游戏结束重新选择;如果坐标处没有雷,统计出附近8个格子中雷的个数并在输入坐标处展现出来;如果输入坐标已经被排查过了,则提示已排查过。

1.演示效果

为了更好的演示,将雷的个数设置为79个,同时将显示出雷的位置的雷盘也展现出来。

具体效果如下:

2.完整代码

#include 
#include 
#include 
#define ROW 9//展现出来的行
#define COL 9//展现出来的列

#define ROWS ROW+2//全部的行
#define COLS COL+2//全部的列

#define MINE 79//雷的个数
void Init_board(char board[ROWS][COLS], int rows, int cols, char set)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < rows; i++)
	{
		for (j = 0; j < cols; j++)
		{
			board[i][j] = set;
		}
	}
}
//打印雷盘
void Print_board(char board[ROWS][COLS], int row, int col)
{
	int i = 0;
	int j = 0;
	for (j = 0; j <= col; j++)
	{
		printf("%d ", j);//打印出来列号
	}
	printf("\n");
	for (i = 1; i <= row; i++)
	{
		printf("%d ",i);//打印出来行号
		for (j = 1; j <= row; j++)
		{
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
}
void Set_mine(char mine[ROWS][COLS], int row, int col)
{
	int count = MINE;
	while (count)
	{
		int x = rand() % row + 1;
		int y = rand() % col + 1;
		if (mine[x][y] == '0')
		{
			mine[x][y] = '1';
			count--;
		}
	}
}
int Get_mine(char mine[ROWS][COLS], int x, int y)
{
	return (mine[x - 1][y] +
		mine[x - 1][y - 1] +
		mine[x][y - 1] +
		mine[x + 1][y - 1] +
		mine[x + 1][y] +
		mine[x + 1][y + 1] +
		mine[x][y + 1] +
		mine[x - 1][y + 1] - 8 * '0');

}
void Find_mine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
	int x = 0;
	int y = 0;
	int win = 0;//走了多少步
	while(win:");
		scanf("%d%d",&x,&y);
		if (x >= 1 && x <= row && y >= 1 && y <= col)
		{
			if (show[x][y] == '*')
			{
				if (mine[x][y] == '1')
				{
					printf("你被炸死了,通关失败!\n");
					show[x][y] = '$';//炸死时用符号$代表所输入的坐标
					Print_board(show, row, col);
					break;
				}
				else
				{
					int count = Get_mine(mine, x, y) + '0';
					show[x][y] = count;
					Print_board(show, row, col);
					win++;
				}
			}
			else
			{
				printf("输入的坐标已被排查过,请重新输入!\n");
			}
		}
		else
		{
			printf("输入的坐标非法,请重新输入!\n");
		}
	}
	if (win == row * col - MINE)
	{
		printf("恭喜你,成功通关!\n");
		Print_board(show, row, col);
	}
}
void game()
{
	//定义两个数组,mine用来记录雷的位置,show展现给玩家
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };
	//初始化雷盘
	//全部初始化为字符0和字符*
	Init_board(mine, ROWS, COLS,'0');
	Init_board(show, ROWS, COLS, '*');

	//打印雷盘
	//Print_board(mine, ROW, COL);
	Print_board(show, ROW, COL);

	//布置雷
	Set_mine(mine, ROW, COL);
	Print_board(mine, ROW, COL);
	
	//排雷
	Find_mine(mine, show, ROW, COL);
}
void menu()
{
	printf("************************\n");
	printf("****  1.开始游戏    ****\n");
	printf("****  0.结束游戏    ****\n");
	printf("************************\n");
}
int main()
{
	int input = 0;
	srand((unsigned int)time(NULL));
	do {
		menu();
		printf("请选择>:");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();
			break;
		case 0:
			printf("游戏结束!\n");
			break;
		default:
			printf("选择错误,请重新选择!\n");
			break;
		}
	} while (input);
}

二、代码解析

1.初始化雷盘

//初始化雷盘
void Init_board(char board[ROWS][COLS], int rows, int cols, char set)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < rows; i++)
	{
		for (j = 0; j < cols; j++)
		{
			board[i][j] = set;
		}
	}
}

char set是用来接收传过来的字符。

2.打印雷盘

//打印雷盘
void Print_board(char board[ROWS][COLS], int row, int col)
{
    int i = 0;
    int j = 0;
    for (j = 0; j <= col; j++)
    {
        printf("%d ", j);//打印出来列号
    }
    printf("\n");
    for (i = 1; i <= row; i++)
    {
        printf("%d ", i);//打印出来行号
        for (j = 1; j <= row; j++)
        {
            printf("%c ", board[i][j]);
        }
        printf("\n");
    }
}

打印雷盘时将其所在的序列号也打印了出来。

3.布置雷

void Set_mine(char mine[ROWS][COLS], int row, int col)
{
    int count = MINE;
    while (count)
    {
        int x = rand() % row + 1;
        int y = rand() % col + 1;
        if (mine[x][y] == '0')
        {
            mine[x][y] = '1';
            count--;
        }
    }
}

通过用rand函数和srand函数生成随机坐标布置雷的位置,一共布置count个雷。

4.排雷

int Get_mine(char mine[ROWS][COLS], int x, int y)
{
    return (mine[x - 1][y] +
        mine[x - 1][y - 1] +
        mine[x][y - 1] +
        mine[x + 1][y - 1] +
        mine[x + 1][y] +
        mine[x + 1][y + 1] +
        mine[x][y + 1] +
        mine[x - 1][y + 1] - 8 * '0');

}
void Find_mine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col)
{
    int x = 0;
    int y = 0;
    int win = 0;//走了多少步
    while (win < row * col - MINE)
    {
        printf("请输入坐标>:");
        scanf("%d%d", &x, &y);
        if (x >= 1 && x <= row && y >= 1 && y <= col)
        {
            if (show[x][y] == '*')
            {
                if (mine[x][y] == '1')
                {
                    printf("你被炸死了,通关失败!\n");
                    show[x][y] = '$';//炸死时用符号$代表所输入的坐标
                    Print_board(show, row, col);
                    break;
                }
                else
                {
                    int count = Get_mine(mine, x, y) + '0';
                    show[x][y] = count;
                    Print_board(show, row, col);
                    win++;
                }
            }
            else
            {
                printf("输入的坐标已被排查过,请重新输入!\n");
            }
        }
        else
        {
            printf("输入的坐标非法,请重新输入!\n");
        }
    }
    if (win == row * col - MINE)
    {
        printf("恭喜你,成功通关!\n");
        Print_board(show, row, col);
    }
}

Get_mine函数用来计算输入坐标附近的雷的个数,通过附近字符1相加之后减去8个字符0计算出来,减去字符0是因为字符1和字符0的ASCII码值相差1,利用这个规则将字符转化为数字。Find_mine函数通过输入的坐标,判断坐标处是否为雷或展现出附近雷的个数亦或者结束游戏。

5.游戏函数主体

void game()
{
	//定义两个数组,mine用来记录雷的位置,show展现给玩家
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };
	//初始化雷盘
	//全部初始化为字符0和字符*
	Init_board(mine, ROWS, COLS, '0');
	Init_board(show, ROWS, COLS, '*');

	//打印雷盘
	//Print_board(mine, ROW, COL);
	Print_board(show, ROW, COL);

	//布置雷
	Set_mine(mine, ROW, COL);
	Print_board(mine, ROW, COL);

	//排雷
	Find_mine(mine, show, ROW, COL);
}

6.菜单函数

void menu()
{
    printf("************************\n");
    printf("****  1.开始游戏    ****\n");
    printf("****  0.结束游戏    ****\n");
    printf("************************\n");
}

7.头文件、宏定义及主函数

#include 
#include 
#include 
#define ROW 9//展现出来的行
#define COL 9//展现出来的列

#define ROWS ROW+2//全部的行
#define COLS COL+2//全部的列

#define MINE 79//雷的个数
int main()
{
	int input = 0;
	srand((unsigned int)time(NULL));
	do {
		menu();
		printf("请选择>:");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();
			break;
		case 0:
			printf("游戏结束!\n");
			break;
		default:
			printf("选择错误,请重新选择!\n");
			break;
		}
	} while (input);
}

以上就是C语言实现扫雷小游戏的示例代码的详细内容,更多关于C语言扫雷游戏的资料请关注码农之家其它相关文章!


参考资料

相关文章

  • C语言中顺序栈和链栈的定义和使用详解

    发布:2023-03-06

    这篇文章主要为大家详细介绍了C语言中顺序栈和链栈的定义和使用,文中的示例代码讲解详细,对我们学习C语言有一定的帮助,感兴趣的小伙伴可以了解一下


  • C语言结构体字节对齐的实现深入分析

    发布:2023-03-05

    这篇文章主要介绍了C语言结构体字节对齐的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧


  • Linux中使用C语言的fork()函数创建子进程的实例教程

    Linux中使用C语言的fork()函数创建子进程的实例教程

    发布:2022-07-25

    给大家整理了关于C语言的教程,fork是一个在Linux系统环境下专有的函数,现有的进程调用fork后将会创建一个新的进程,这里我们就来看一下Linux中使用C语言的fork()函数创建子进程的实例教程


  • C语言实现打印数字金字塔

    发布:2023-03-11

    这篇文章主要介绍了C语言实现打印数字金字塔方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教


  • C语言读取文件流的相关函数用法简介

    发布:2023-01-05

    为网友们分享了关于C语言的教程,这篇文章主要介绍了C语言读取文件流的相关函数用法简介,包括fread()函数和feof()函数的使用,需要的朋友可以参考下


  • C语言数据结构不挂科指南之队列详解

    发布:2023-03-02

    这篇博客主要介绍一下队列的概念,并且采用 C 语言,编写两种存储实现方式:顺序存储和链式存储,当然还有常规的队列基本操作的实现算法


  • C语言动态内存管理malloc柔性数组示例详解

    发布:2023-03-07

    这篇文章主要为大家介绍了C语言动态内存管理malloc柔性数组示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • C语言实现猜数字小游戏的示例代码

    发布:2023-03-06

    猜数字小游戏是我们小时候喜欢我们一个经典小游戏。这篇文章将利用C语言中的循环语句、分支语句和函数实现这一游戏,需要的可以参考一下


网友讨论