IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言之扫雷 -> 正文阅读

[C++知识库]C语言之扫雷

逻辑代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"

void menu()
{
	printf(" 游戏菜单\n");
	printf("1. play\n");
	printf("2. exit\n");
}

void ruler()
{
	printf("\n");
	printf("           扫雷游戏规则\n");
	printf("\n");
	printf("输入严格按照以下要求:\n");
	printf("1. 输入完记得按下回车键才起效果!\n");
	printf("2. 坐标中间加空格!\n");
	printf("   例如 想输入坐标55\n");
	printf("   应该输入5 5(中间有空格)\n");
	printf("   输入完再按下回车即可\n");
	printf("\n");
	printf("如果明白了,那按照以上规则输入完坐标55以后进入游戏菜单吧!\n");
	int i = 0;
	int j = 0;
	scanf("%d %d", &i, &j);
	system("cls");
}

void game()
{
	char mine[ROWS][COLS] = { 0 };//存放雷的信息
	char show[ROWS][COLS] = { 0 };//存放排查好雷的信息

	//初始化函数
	Initboard(mine, ROWS, COLS, '0');//初始化mine数组
	Initboard(show, ROWS, COLS, '*');//初始化show数组

	//布置雷的信息
	Setmine(mine, ROW, COL);
	
	//打印棋盘
	Displayboard(show, ROW, COL);
	//Displayboard(mine, ROW, COL);

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


void test()
{
	int input = 0;
	int i = 0;
	ruler();
	menu();
	scanf("%d", &input);
here:
	system("cls");
	switch (input)
	{
	case 1:
		game();
		printf("   是否继续游戏?\n");
		printf("1. continue    2. exit \n");
		int i = 0;
		scanf("%d", &i);
		system("cls");
		if (i == 1)
		{
			goto here;
		}
		else
		{
			goto there;
		}
		break;
	case 2:
	there:
		printf("game over!\n");
		break;
	default:
		printf("please input again!\n");
		break;
	}
}


int main()
{	
	srand((unsigned int)time(NULL));
	test();
	return 0;
}

游戏需要的头文件:

#pragma once

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <windows.h>

//真正操作对象
#define ROW 9 
#define COL 9

//用这个来防止越界问题
#define ROWS ROW+2
#define COLS COL+2

#define MINE_MAX 10

//初始化雷的信息
void Initboard(char arr[ROWS][COLS], int rows, int cols, char set);

//打印棋盘
void Displayboard(char arr[ROWS][COLS], int row, int col);

//布置雷的信息
void Setmine(char mine[ROWS][COLS], int row, int col);

//排雷
void  Finemine(char mine[ROWS][COLS], char show[ROWS][COLS], int row, int col);

游戏本体代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include "game.h"

void Initboard(char arr[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++)
		{
			arr[i][j] = set;
		}
	}
}

void Displayboard(char arr[ROWS][COLS], int row, int col)
{
	int i = 0;
	for (i = 0; i <= col; i++)
	{
		printf("%d ", i);
	}
	printf("\n");
	for (i = 1; i <= row; i++)
	{
		int j = 0;
		printf("%d ", i);
		for (j = 1; j <= col; j++)
		{
			printf("%c ", arr[i][j]);
		}
		printf("\n");
	}
}

void Setmine(char mine[ROWS][COLS], int row, int col)
{
	int count = MINE_MAX;

	while (count)
	{
		int x = rand() % row + 1;
		int y = rand() % col + 1;
		if (mine[x][y] == '0')
		{
			mine[x][y] = '1';
			count--;
		}
	}
}

//为了不让其他地方用到这个函数
 static int Get_mine_count(char mine[ROWS][COLS], int x, int y)
{
	return mine[x - 1][y] +
		mine[x - 1][y - 1] +
		mine[x - 1][y + 1] +
		mine[x][y - 1] +
		mine[x][y + 1] +
		mine[x + 1][y] +
		mine[x + 1][y - 1] +
		mine[x + 1][y] - 8 * '0';
}

void  Finemine(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_MAX)
	{
		printf("请输入你想要排雷的坐标:\n");
        scanf("%d %d", &x, &y);
		system("cls");
		printf("\n");
		if (x >= 1 && x <= row && y >= 1 && y <= col)
		{
			if (mine[x][y] == '1')
			{
				printf("You are die!\n");
				Sleep(3000);
				system("cls");
				printf("\n");
				printf("雷的分布如下:");
				printf("(0代表安全的位置,1代表雷的位置)\n");
				Displayboard(mine, ROW, COL);
				Sleep(3000);
				break;
			}
			else
			{
				//计算附近有多少个雷
				int n = Get_mine_count(mine, x, y);
				show[x][y] = n + '0';
				Displayboard(show, row, row);
				win++;
			}
		}
		else
		{
			printf("Plese input again!\n");
			printf("\n");
			Displayboard(show, row, row);
		}
	}
	if (win == row * col - MINE_MAX)
	{
		Sleep(2000);
		system("cls");
		printf("You are win!\n");
		Sleep(2000);
		system("cls");
	}
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:04:24  更:2022-03-16 22:06:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:04:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码