【C语言】扫雷【附源码】

news2024/11/25 18:51:56

欢迎来到英杰社区icon-default.png?t=N7T8https://bbs.csdn.net/topics/617804998

一、扫雷游戏规则

       尽快找到雷区中的所有不是地雷的格子,而不许踩到地雷。点开的数字是几,则说明该数字旁边的8个位置中有几个雷,如果挖开的是地雷,则会输掉游戏。

二、代码思路:

  • 宏定义

    • RowCol 定义了棋盘的行数和列数。
    • RowsCols 分别定义了棋盘数组的行数和列数,多出来的两行两列是为了在棋盘的四周留出空白区域。
    • EASY 定义了简单难度下的地雷数量。
  • 函数原型

    • InitBoard():初始化棋盘函数原型,用于在程序的其他地方实现初始化棋盘的功能。
    • DisplayBoard():打印棋盘函数原型,用于在程序的其他地方实现打印棋盘的功能。
    • SetMine():布置地雷函数原型,用于在程序的其他地方实现布置地雷的功能。
    • FindMine():找地雷函数原型,用于在程序的其他地方实现找地雷的功能。
  • 菜单函数 menu()

    •  这个函数用于显示游戏的菜单界面,提供了两个选项:开始游戏和退出游戏。 
    void menu() {
    	printf("*****************************\n");
    	printf("*****************************\n");
    	printf("***********1.play************\n");
    	printf("***********0.exit************\n");
    	printf("*****************************\n");
    	printf("*****************************\n");
    	printf("*****************************\n");
    
    
    }

  • 主函数 main()

    • main() 函数中,首先声明了一个整型变量 input,用于接收用户的输入选项。
    • 进入一个 do-while 循环,这个循环会一直执行,直到用户选择退出游戏(输入 0)。
    • 在循环内部,首先调用 menu() 函数显示菜单界面,然后通过 scanf() 函数获取用户的选择,并存储在 input 变量中。
    • 使用 switch 语句根据用户的选择执行相应的操作:
      • 如果用户选择 1,则调用 game() 函数开始游戏。
      • 如果用户选择 0,则打印消息表示退出游戏。
      • 如果用户输入其他数字,则提示用户重新选择。
    • 循环条件是 input != 0,即只要用户不选择退出游戏,就会一直循环显示菜单。
    int main()
    {
    	srand((unsigned int)time(NULL));
    	int input = 0;
    	do {
    		menu();
    		printf("请选择:");
    		scanf("%d", &input);
    		switch (input) {
    		case 1:
    			game();
    			break;
    		case 0:
    			printf("退出游戏");
    			break;
    		default:
    			printf("输入错误请重新输入");
    			break;
    
    		}
    	} while (input);
    	return 0;
    }

  • 游戏函数 game()

    • 这个函数负责实现扫雷游戏的核心逻辑。
    • 首先声明了两个二维字符数组 mineshow,用于存储扫雷棋盘的地雷分布情况和显示给玩家的棋盘情况。
    • 调用 InitBoard() 函数初始化两个棋盘。
    • 调用 SetMine() 函数设置地雷的位置。
    • 调用 DisplayBoard() 函数显示初始的棋盘给玩家。
    • 最后调用 FindMine() 函数开始游戏,排查地雷并更新显示给玩家的棋盘。
    void game() {
    	char mine[Rows][Cols];
    	char show[Rows][Cols];
    	InitBoard(mine, Rows, Cols, '0');
    	InitBoard(show, Rows, Cols, '*');
    	DisplayBoard(mine, Row, Col);
    	DisplayBoard(show, Row, Col);
    	SetMine(mine, Row, Col);
    	//DisplayBoard(mine, Row, Col);
    	FindMine(mine, show, Row, Col);
    }

  • InitBoard() 函数
  • 用于初始化棋盘,将棋盘的每个格子都设置为指定的字符 set
  • 参数 rowscols 分别表示棋盘的行数和列数。
void InitBoard(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;
		}
	}
}

  • DisplayBoard() 函数

    1. 用于显示棋盘的当前状态,包括地雷和已经排查的区域。
    2. 打印出棋盘的行号和列号,以及对应位置的字符。
    3. 参数 rowcol 表示棋盘的行数和列数。
void DisplayBoard(char board[Rows][Cols], int row, int col) {
	int i = 0;
	int j = 0;
	printf("----------  扫雷 -----------\n");
	for (i = 0; i <= col; i++) {
		printf("%d ", i);
	}
	printf("\n");
	for (i = 1; i <= row; i++) {
		printf("%d ", i);
		for (j = 1; j <= col; j++) {
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
	printf("----------  扫雷 -----------\n");
}

  • SetMine() 函数

    1. 用于设置地雷在棋盘上的位置。
    2. 参数 rowcol 分别表示棋盘的行数和列数。
    3. 使用 rand() 函数生成随机数,随机设置地雷的位置。
    4. count 变量表示地雷的数量,根据不同的难度(这里是简单难度)来设置地雷的数量。
void SetMine(char board[Rows][Cols], int row, int col) {
	int count = EASY;
	while (count) {
		int x = rand() % row + 1;
		int y = rand() % col + 1;
		if (board[x][y] == '0') {
			board[x][y] = '1';
			count--;
		}


	}
}
  • GetMineCount() 函数

    1. 用于统计某个位置周围地雷的数量。
    2. 参数 xy 表示要统计的位置坐标。
    3. 遍历该位置周围的八个方向,统计周围地雷的数量。
int GetMineCount(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';
}
  • FindMine() 函数

    1. 实现了玩家排雷的过程。
    2. 使用 while 循环,直到排查完所有非地雷的位置或者踩到地雷为止。
    3. 每次循环提示玩家输入坐标,然后判断该位置是否有地雷。
    4. 如果踩到地雷,则游戏失败,显示所有地雷的位置。
    5. 如果没有踩到地雷,则统计周围地雷的数量,并更新显示给玩家的棋盘。
    6. 循环结束后,根据游戏是否成功来显示相应的消息
void FindMine(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 - EASY) {
		printf("请输入坐标:");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= row && y >= 1 && y <= col) {
			if (mine[x][y] == '1') {
				printf("炸死了\n");
				DisplayBoard(mine, Row, Col);
				break;
			}
			else//统计周围有几个地雷
			{
				int sum = GetMineCount(mine, x, y);
				show[x][y] = sum + '0';//1+'0'='1'
				DisplayBoard(show, Row, Col);
				win++;
			}

		}
		else {
			printf("坐标错误重新输入");
		}
	}
	if (win == Row * Col - EASY) {
		printf("恭喜你排雷成功");
		DisplayBoard(mine, Row, Col);

	}
}

三、完整代码

        test.c

        

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void menu() {
	printf("*****************************\n");
	printf("*****************************\n");
	printf("***********1.play************\n");
	printf("***********0.exit************\n");
	printf("*****************************\n");
	printf("*****************************\n");
	printf("*****************************\n");


}
void game() {
	char mine[Rows][Cols];
	char show[Rows][Cols];
	InitBoard(mine, Rows, Cols, '0');
	InitBoard(show, Rows, Cols, '*');
	DisplayBoard(mine, Row, Col);
	DisplayBoard(show, Row, Col);
	SetMine(mine, Row, Col);
	//DisplayBoard(mine, Row, Col);
	FindMine(mine, show, Row, Col);
}
int main()
{
	srand((unsigned int)time(NULL));
	int input = 0;
	do {
		menu();
		printf("请选择:");
		scanf("%d", &input);
		switch (input) {
		case 1:
			game();
			break;
		case 0:
			printf("退出游戏");
			break;
		default:
			printf("输入错误请重新输入");
			break;

		}
	} while (input);
	return 0;
}

        game.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"
void InitBoard(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 DisplayBoard(char board[Rows][Cols], int row, int col) {
	int i = 0;
	int j = 0;
	printf("----------  扫雷 -----------\n");
	for (i = 0; i <= col; i++) {
		printf("%d ", i);
	}
	printf("\n");
	for (i = 1; i <= row; i++) {
		printf("%d ", i);
		for (j = 1; j <= col; j++) {
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
	printf("----------  扫雷 -----------\n");
}
void SetMine(char board[Rows][Cols], int row, int col) {
	int count = EASY;
	while (count) {
		int x = rand() % row + 1;
		int y = rand() % col + 1;
		if (board[x][y] == '0') {
			board[x][y] = '1';
			count--;
		}


	}
}
int GetMineCount(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 FindMine(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 - EASY) {
		printf("请输入坐标:");
		scanf("%d %d", &x, &y);
		if (x >= 1 && x <= row && y >= 1 && y <= col) {
			if (mine[x][y] == '1') {
				printf("炸死了\n");
				DisplayBoard(mine, Row, Col);
				break;
			}
			else//统计周围有几个地雷
			{
				int sum = GetMineCount(mine, x, y);
				show[x][y] = sum + '0';//1+'0'='1'
				DisplayBoard(show, Row, Col);
				win++;
			}

		}
		else {
			printf("坐标错误重新输入");
		}
	}
	if (win == Row * Col - EASY) {
		printf("恭喜你排雷成功");
		DisplayBoard(mine, Row, Col);

	}
}

        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 10
void InitBoard(char board[Rows][Cols], int rows, int cols, char set);//初始化棋盘
void DisplayBoard(char board[Rows][Cols], int row, int col);//打印棋盘
void SetMine(char board[Rows][Cols], int row, int col);//布置地雷
void FindMine(char mine[Rows][Cols], char show[Rows][Cols], int row, int col);//找地雷

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1580369.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Laravel 项目如何运行

如有一个 Laravel 项目&#xff0c;在配置好 PHP 版本和运行环境后&#xff0c;可以直接在项目下直接运行&#xff1a; php artisan serve 来启动你的项目。 通过浏览器查看 当项目运行后&#xff0c;默认的启动端口为 8000&#xff0c;可以通过浏览器来进行查看运行的 Larav…

C++性能测试工具

使用示例main.cpp // g-13 -O3 -stdc17 main.cpp profile.cpp #include <iostream> #include <chrono> #include <stdint.h> #include <mutex> // std::mutex#include "profile.h" #include "profile_rdtsc.h"std::mut…

GlusterFS分布式文件系统

一、GlusterFS简介 GlusterFS 是一个开源的分布式文件系统。由存储服务器、客户端以及NFS/Samba存储网关(可选&#xff0c;根据需要选择使用)组成。没有元数据服务器组件&#xff0c;这有助于提升整个系统的性能、可靠性和稳定性 二、GlusterFS特点 2.1 扩展性和高性能 Glu…

Tensorboard以及Transforms初步学习

一.前情提要 1.本文是代码结合知识点&#xff0c;注释即为知识点 2.主要详细讲解Tensorboard以及Transforms代码以及基础知识 3.若想深入学习&#xff0c;建议阅读 P3. Python学习中的两大法宝函数&#xff08;当然也可以用在PyTorch&#xff09;_哔哩哔哩_bilibili 二.简述…

Scala中如何使用Jsoup库处理HTML文档?

在当今互联网时代&#xff0c;数据是互联网应用程序的核心。对于开发者来说&#xff0c;获取并处理数据是日常工作中的重要一环。本文将介绍如何利用Scala中强大的Jsoup库进行网络请求和HTML解析&#xff0c;从而实现爬取京东网站的数据&#xff0c;让我们一起来探索吧&#xf…

云智慧发布对象关系型数据库CloudPanguDB,打破传统技术壁垒

近日&#xff0c;云智慧推出关系型数据库CloudPanguDB&#xff08;中文名称&#xff1a;盘古数据库&#xff09;&#xff0c;旨在通过高兼容性能和创新技术架构&#xff0c;降低企业项目整体运营成本。 无论是处理海量复杂数据&#xff0c;还是构建清晰有序的数据结构关系&…

c++ 谷歌glog日志库使用

效果如图&#xff1a; 本次使用qt环境演示&#xff0c;相关库文件和头文件下载链接&#xff1a;https://download.csdn.net/download/bangtanhui/89108477 将相关库文件和头文件&#xff0c;丢到工程目录下 然后需要在工程pro文件当中引入库文件和头文件&#xff1a; …

创建型模式--2.简单工厂模式【人造恶魔果实工厂1】

1. 工厂模式的特点 在海贼王中&#xff0c;作为原王下七武海之一的多弗朗明哥&#xff0c;可以说是新世界最大的流氓头子&#xff0c;拥有无上的权利和无尽的财富。他既是德雷斯罗萨国王又是地下世界的中介&#xff0c;控制着世界各地的诸多产业&#xff0c;人造恶魔果实工厂就…

Java Web这一路走来

大部分Java应用都是Web或网络应用&#xff0c;MVC框架在Java框架中有着举足轻重的地位&#xff0c;一开始的Web应用并不现在这样子的&#xff0c;一步一步走来&#xff0c;每一步都经历了无数的血和泪的教训&#xff0c;以史为镜可以知兴替。 1. 草莽时代 早期的Java服务端技…

使用ollydbg还原密码程序的密码

前言&#xff1a;我们上次用ida pro破解了程序密码这次我们换个工具来还原程序密码 第一步 和上次一样把找到的程序拖到ollydbg里面 第二步 右键点击查找所有引用字符串 第三步 找到报错代码双击进入 第五步 找到上面的jnz双击将其改成jz 第六步 将所修改的保存点击空白…

FPGA(Verilog)实现uart传输协议传输数据(含仿真)

目录 实现功能&#xff1a; 1.接收uart串行数据&#xff0c;输出并行数据(1byte)。 2.输入并行数据(1byte)&#xff0c;输出uart串行数据。 3.完成uart传输的1次环回。 uart协议的1帧数据传输 模块封装-port设置 Verilog代码实现 1.uart接收模块:接收串行数据,输出并行数…

基于Java+SpringBoot+Vue企业员工管理系统(源码+文档+部署+讲解)

一.系统概述 随着社会的发展&#xff0c;系统的管理形势越来越严峻。越来越多的用户利用互联网获得信息&#xff0c;但各种信息鱼龙混杂&#xff0c;信息真假难以辨别。为了方便用户更好的获得信息&#xff0c;因此&#xff0c;设计一种安全高效的员工管理系统极为重要。 为设计…

swiftui macOS实现加载本地html文件

import SwiftUI import WebKitstruct ContentView: View {var body: some View {VStack {Text("测试")HTMLView(htmlFileName: "localfile") // 假设你的本地 HTML 文件名为 index.html.frame(minWidth: 100, minHeight: 100) // 设置 HTMLView 的最小尺寸…

【攻防世界】php_rce (ThinkPHP5)

进入题目环境&#xff0c;查看页面信息&#xff1a; 页面提示 ThinkPHP V5&#xff0c;猜测存在ThinkPHP5 版本框架的漏洞&#xff0c;于是查找 ThinkPHP5 的攻击POC。 构造 payload: http://61.147.171.105:50126/?sindex/think\app/invokefunction&functioncall_user_f…

续写Groq

这章写点Groq干货,理性的分析。 首先是Articical Analysis的关于Mixtral8*7B的吞吐比较 上图是有Mixtral 8*7BPaaS服务的AI服务商,Mistral自己居然排倒数第三 ,Groq是真的遥遥领先啊。 另外这个图是比较每100万tokens的cost,无论是推理速度还是cost,Groq都是遥遥领先…

如何把1G多的视频压缩到500兆以内?3个方法轻松减小文件内存~

微信已经成为了我们上班交流沟通时必不可少的通讯工具之一&#xff0c;在使用微信时&#xff0c;常常会遇到系统提示发送的word、ppt、pdf文件、视频、压缩包等文件超过1G&#xff0c;无法发送。有没有什么办法可以缩小文件的体积呢&#xff1f;今天给大家介绍几款可以用于视频…

Python中Python-docx 包的run介绍

先对run做一个简单地介绍。每个paragraph对象都包含一个run对象的列表。举例&#xff1a; 这是一个简短的段落。 from docx import Document doc Document("1.docx") #上面这段话保存在1.docx中 print("这一段的run个数是&#xff1a;",len(doc.paragr…

leetcode热题100.划分字母区间

Problem: 763. 划分字母区间 文章目录 题目思路复杂度Code 题目 给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段&#xff0c;同一字母最多出现在一个片段中。 注意&#xff0c;划分结果需要满足&#xff1a;将所有划分结果按顺序连接&#xff0c;得到的字符串仍…

基于Leaflet.js和Turf.js的等值线区间自定义及颜色自适应实践

目录 前言 一、Turf.js等值线相关制作 1、生成方法 2、主要参数 二、实际案例开发 1、新建展示页面 2、等值线生成 3、基于Leaflet的再优化 总结 前言 在气象方面的GIS应用当中&#xff0c;会根据实际的工作需要建立不同的监测站点。气象监测站的主要功能包括&#xff1…

如何快速识别陶瓷件的外观缺陷吗?

陶瓷件由陶瓷材料制成的物品或零部件&#xff0c;通常用于装饰、日常生活用品、工艺品或工业应用。陶瓷是一种非金属材料&#xff0c;具有耐高温、耐磨损、绝缘、化学稳定等特性&#xff0c;因此在许多领域得到广泛应用。 本案针对陶瓷件尺寸长25mm*宽11mm*高2mm的产品的外观检…