老程序员教你一天时间完成C语言扫雷游戏

 更新时间:2021年08月13日 10:29:24   作者:Ja_king_  
这篇文章主要为大家详细介绍了C语言实现扫雷游戏初级版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

扫雷游戏

在这里插入图片描述

今天我们就要设计一款这样的游戏,首先需要设置棋盘,然后对棋盘进行随机布雷,最后在排雷。

1.菜单

首先制作一个简易菜单

int main() {
	int input;
	srand((unsigned int)time(NULL));
	do {
		menu();
		printf("请选择:\n");
		scanf("%d", &input);
		switch (input) {
		case 1:
			game();
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("选择错误\n");
			break;
		}

	} while(input);
	return 0;
}

效果如下:
在这里插入图片描述

2.初始化棋盘

首先需要设置两个二维数组,分别存放雷的信息和排查出雷的信息

	char mine[ROWS][COLS] = { 0 };//存放雷的信息
	char show[ROWS][COLS] = { 0 };//存放排查出雷的信息

然后对其进行初始化

//初始化棋盘

void InitBoard(char board[ROWS][COLS], int rows, int cols,char set) {
	for (int i = 0;i < rows;i++) {
		for (int j = 0;j < cols;j++) {
			board[i][j] = set;
		}
	}
}

3.打印棋盘

棋盘的打印可以直接遍历二维数组,并加上一些分割线

void PrintBoard(char board[ROWS][COLS], int row, int col) {
	printf("--------扫雷--------\n");
	for (int i = 0;i <= 9;i++) {
		printf("%d ", i);
	}
	printf("\n");

	for (int i = 1;i < row+1 ;i++) {
		printf("%d ", i);
		for (int j = 1;j < col+1;j++) {
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
	printf("--------------------\n");

}

打印出来的棋盘如下

在这里插入图片描述

4.布置雷

棋盘打印出来了,接下来就是在棋盘上随机布雷

void SetMine(char board[ROWS][COLS], int row, int col) {
	int count = EASY_COUNT;
	while (count) {
		int x = rand() % 9 + 1;
		int y = rand() % 9 + 1;
		if (board[x][y] != '1') {
			board[x][y] = '1';
			count--;
		}	
	}
}

5.排查雷

排查雷采用玩家输入坐标,对比观察该坐标是否有雷并给出提示,提示显示该坐标周围有几个雷或者是否被炸死

//排查雷
int GetMineCount(char board[ROWS][COLS],int x,int y) {
	int count=0;
	for (int i = x - 1;i <= x + 1;i++) {
		for (int j = y - 1;j <= y + 1;j++) {
			count += (board[i][j]-'0');
		}
	}
	return count;
}

void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col) {
	int x, y,win=0;
	while (win<row*col-EASY_COUNT) {
		printf("请输入坐标\n");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= row && y >= 1 && y <= col) {
			if (mine[x][y] != '1') {
				int count = GetMineCount(mine,x,y);
				show[x][y] = count + '0';
				PrintBoard(show, ROW, COL);
				win++;
			}
			else {
				printf("很遗憾,你被炸死了\n");
				PrintBoard(mine, ROW, COL);
				break;
			}
		}
		else {
			printf("坐标非法,请重新输入\n");
		}
	}
	if (win == row * col - EASY_COUNT) {
		printf("恭喜你,排雷成功\n");
		PrintBoard(mine, ROW, COL);
	}
		
}

6.整体效果展示

在这里插入图片描述

7.代码分享

7.1 test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
void menu() {
	printf("*********************************\n");
	printf("*********    1. play   **********\n");
	printf("*********    0. exit   **********\n");
	printf("*********************************\n");
}
void game() {
	char mine[ROWS][COLS] = { 0 };//存放雷的信息
	char show[ROWS][COLS] = { 0 };//存放排查出雷的信息
	//初始化棋盘
	InitBoard(mine, ROWS, COLS,'0');
	InitBoard(show, ROWS, COLS,'*');
	//打印棋盘
	//PrintBoard(mine, ROW, COL);
	PrintBoard(show, ROW, COL);

	//布置雷
	SetMine(mine, ROW, COL);
	//PrintBoard(mine, ROW, COL);

	//排查雷
	FindMine(mine, show, ROW, COL);

}
int main() {
	int input;
	srand((unsigned int)time(NULL));
	do {
		menu();
		printf("请选择:\n");
		scanf("%d", &input);
		switch (input) {
		case 1:
			game();
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("选择错误\n");
			break;
		}

	} while(input);
	return 0;
}

7.2 game.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"

//初始化棋盘

void InitBoard(char board[ROWS][COLS], int rows, int cols,char set) {
	for (int i = 0;i < rows;i++) {
		for (int j = 0;j < cols;j++) {
			board[i][j] = set;
		}
	}
}

//打印棋盘

void PrintBoard(char board[ROWS][COLS], int row, int col) {
	printf("--------扫雷--------\n");
	for (int i = 0;i <= 9;i++) {
		printf("%d ", i);
	}
	printf("\n");

	for (int i = 1;i < row+1 ;i++) {
		printf("%d ", i);
		for (int j = 1;j < col+1;j++) {
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
	printf("--------------------\n");

}

//设置雷

void SetMine(char board[ROWS][COLS], int row, int col) {
	int count = EASY_COUNT;
	while (count) {
		int x = rand() % 9 + 1;
		int y = rand() % 9 + 1;
		if (board[x][y] != '1') {
			board[x][y] = '1';
			count--;
		}	
	}
}

//排查雷
int GetMineCount(char board[ROWS][COLS],int x,int y) {
	int count=0;
	for (int i = x - 1;i <= x + 1;i++) {
		for (int j = y - 1;j <= y + 1;j++) {
			count += (board[i][j]-'0');
		}
	}
	return count;
}

void FindMine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col) {
	int x, y,win=0;
	while (win<row*col-EASY_COUNT) {
		printf("请输入坐标\n");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= row && y >= 1 && y <= col) {
			if (mine[x][y] != '1') {
				int count = GetMineCount(mine,x,y);
				show[x][y] = count + '0';
				PrintBoard(show, ROW, COL);
				win++;
			}
			else {
				printf("很遗憾,你被炸死了\n");
				PrintBoard(mine, ROW, COL);
				break;
			}
		}
		else {
			printf("坐标非法,请重新输入\n");
		}
	}
	if (win == row * col - EASY_COUNT) {
		printf("恭喜你,排雷成功\n");
		PrintBoard(mine, ROW, COL);
	}
		
}

7.3 game.h

#pragma once
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define ROW 9
#define COL 9
#define ROWS ROW+2
#define COLS COL+2
#define EASY_COUNT 10

//初始化棋盘
void InitBoard(char board[ROWS][COLS], int rows, int cols,char set);
//打印棋盘
void PrintBoard(char board[ROWS][COLS], int row, int col);
//设置雷
void SetMine(char board[ROWS][COLS], int row, int col);
//排查雷
void FindMine(char board1[ROWS][COLS], char board2[ROWS][COLS], int row, int col);

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • C语言三种方法解决轮转数组问题

    C语言三种方法解决轮转数组问题

    这篇文章主要给大家讲解轮转数组的问题,一个问题不局限于一种解法,希望你看了本文的解决方法以后可以举一反三自己编写,这样你的技术水平会有质的提高
    2022-04-04
  • C语言详细分析讲解流程控制语句用法

    C语言详细分析讲解流程控制语句用法

    C语言语句的执行默认顺序执行(从上往下依次执行),编程语言一般除了默认的顺序执行以外,还提供分支执行和循环执行的语法,让我们一起来看看
    2022-05-05
  • map插入自定义对象总结

    map插入自定义对象总结

    黑树在插入节点时,必须依照大小比对之后在一个合适的位置上执行插入动作。所以作为关键字,起码必须有“<”这个比较操作符
    2013-09-09
  • Qt+GDAL库实现制作经纬度坐标转换工具

    Qt+GDAL库实现制作经纬度坐标转换工具

    这篇文章主要为大家详细介绍了如何利用Qt和GDAL库实现制作经纬度坐标转换工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-04-04
  • 一文详解C++中的引用与关键字auto

    一文详解C++中的引用与关键字auto

    引用就是给一个已经存在的变量取一个别名,与变量共用一段内存空间。关键字auto一般可以用来自动识别类型,本文主要来讲讲二者的相关知识,需要的可以参考一下
    2023-04-04
  • Pipes实现LeetCode(193.验证电话号码)

    Pipes实现LeetCode(193.验证电话号码)

    这篇文章主要介绍了Pipes实现LeetCode(193.验证电话号码),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C语言动态规划点杀dp算法LeetCode炒股习题案例解析

    C语言动态规划点杀dp算法LeetCode炒股习题案例解析

    这篇文章主要介绍为了C语言动态规划点杀dp算法,本文以LeetCode炒股习题案例来为大家进行详细解析,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2022-02-02
  • C++ vector使用的一些注意事项

    C++ vector使用的一些注意事项

    这篇文章主要给大家介绍了关于C++ vector使用的一些注意事项,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • 纯C语言:检索与周游广度深度遍历源码分享

    纯C语言:检索与周游广度深度遍历源码分享

    这篇文章主要介绍了检索与周游广度深度遍历源码,有需要的朋友可以参考一下
    2014-01-01
  • 浅析C语言中printf(),sprintf(),scanf(),sscanf()的用法和区别

    浅析C语言中printf(),sprintf(),scanf(),sscanf()的用法和区别

    以下是对C语言中printf(),sprintf(),scanf(),sscanf()的用法以及区别进行了详细的分析介绍,需要的朋友可以参考下
    2013-07-07

最新评论