C语言扫雷游戏完整实现(下)

文章目录

  • 前言
  • 一、排雷函数菜单
  • 二、排雷函数菜单的实现
  • 三、拓展棋盘功能
  • 四、源码
    • 1. test.c源文件
    • 2. game.h头文件
    • 3. game.c源文件
  • 总结


前言

C语言实现扫雷游戏的排雷菜单,以及功能的实现,拓展棋盘功能,以及源码等。

上半部分的链接地址: C语言扫雷游戏完整实现(上)

一、排雷函数菜单

  • 排雷函数菜单就只有1.排雷 和 2. 退出两个选择。
//test.c 源文件
void game()
{
	int choose = 0;
	int count = 0;
	int sum = 0;
	// 定义两个二维数组
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };

	// 初始化棋盘
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

	// 布置雷
	SetBoard(mine, ROW, COL);

	// 打印棋盘
	DisplayBoard(mine, ROW, COL);
	DisplayBoard(show, ROW, COL);

	// 玩家开始排雷
	do
	{
		printf("****************\n");
		printf("*** 1. 标记  ***\n");
		printf("*** 2. 排雷  ***\n");
		printf("*** 0. 退出  ***\n");
		printf("****************\n");
		printf("请选择:>");
		scanf("%d", &choose);

		if (1 == choose)
		{
			count = SignBoard(show, mine, ROW, COL);
			if (count != 0)
			{
				printf("恭喜你,排雷成功!!\n");
				break;
			}
		}
		else if (2 == choose)
		{
			printf("排雷功能\n"); // 可以删除
			sum = FineBoard(show, mine, ROW, COL);
		}
		else if (0 == choose)
		{
			printf("退出游戏\n");
			break;
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (choose);

}


//game.h 头文件
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define ROW 9
#define COL 9

#define ROWS ROW + 2
#define COLS COL + 2

#define EASY_COUNT 1

// 初始化函数声明
void InitBoard(char board[ROWS][COLS], int rows, int cols, char sign);


// 打印函数声明
void DisplayBoard(char board[ROWS][COLS], int row, int col);

// 布置雷函数声明
void SetBoard(char board[ROWS][COLS], int row, int col);

// 标记功能函数声明
int SignBoard(char show[ROWS][COLS],char mine[ROWS][COLS], int row, int col);

// 排雷函数声明
int FineBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col);

//game.c 源文件 -- FineBoard函数菜单部分
// 排雷函数声明
int FineBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col)
{
	int goway = 0;
	do
	{
		printf("**************\n");
		printf("*** 1.排雷 ***\n");
		printf("*** 0.退出 ***\n");
		printf("**************\n");
		printf("请选择:>");
		scanf("%d", &goway);
		if (1 == goway)
		{
			printf("排雷开始\n");
		}
		else if (0 == goway)
		{
			printf("退出游戏\n");
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (goway);

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

二、排雷函数菜单的实现

  • 玩家需要输入坐标,若超出范围或不合法应该重新输入,所以要用循环
  • 若玩家选择的位置不是雷,则显示周围雷的个数。
//test.c 源文件-- game函数
void game()
{
	int choose = 0;
	int count = 0;
	int sum = 0;
	// 定义两个二维数组
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };

	// 初始化棋盘
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

	// 布置雷
	SetBoard(mine, ROW, COL);

	// 打印棋盘
	DisplayBoard(mine, ROW, COL);
	DisplayBoard(show, ROW, COL);

	// 玩家开始排雷
	do
	{
		printf("****************\n");
		printf("*** 1. 标记  ***\n");
		printf("*** 2. 排雷  ***\n");
		printf("*** 0. 退出  ***\n");
		printf("****************\n");
		printf("请选择:>");
		scanf("%d", &choose);

		if (1 == choose)
		{
			count = SignBoard(show, mine, ROW, COL);
			if (count != 0)
			{
				printf("恭喜你,排雷成功!!\n");
				break;
			}
		}
		else if (2 == choose)
		{
			printf("排雷功能\n");
			sum = FineBoard(show, mine, ROW, COL);
			if (-1 == sum)
			{
				printf("恭喜你,排雷成功!!\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}
			else if (404 == sum)
			{
				printf("很遗憾,你被炸死了!\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}

		}
		else if (0 == choose)
		{
			printf("退出游戏\n");
			break;
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (choose);

}

//game.c 源文件-- FindBoard函数和BoomCount函数
// 计算周围雷的个数函数
int BoomCount(char board[ROWS][COLS], int x, int y)
{
	int i = 0;
	int sum = 0;

	for (i = -1; i <= 1; i++)
	{
		int j = 0;
		for (j = -1; j <= 1; j++)
		{
			if (i == j && 0 == j)
			{
				continue;
			}
			sum = sum +  board[x+i][y+j] - '0';
		}

	}
	return sum;
}



// 排雷函数声明
int FineBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col)
{
	int goway = 0;
	int x = 0;
	int y = 0;
	static int number = 0;
	do
	{
		printf("**************\n");
		printf("*** 1.排雷 ***\n");
		printf("*** 0.取消 ***\n");
		printf("**************\n");
		printf("请选择:>");
		scanf("%d", &goway);
		if (1 == goway)
		{
			while (1)
			{
				printf("请输入排雷坐标(空格间隔):");
				scanf("%d %d", &x, &y);

				if (x >= 1 && x <= row && y >= 1 && y <= col) // 判断坐标合法性
				{
					if (show[x][y] == '*') // 判断是否被排查
					{
						if (mine[x][y] == '1')
						{
							return 404;
						}
						else
						{
							// 调用计算周围雷个数的函数
							int bct = BoomCount(mine, x, y);
							show[x][y] = bct + '0';
							DisplayBoard(show, ROW, COL);
							number++;
							break;
						}

					}
					else
					{
						printf("此位置已经排查完,请勿重复排查\n");
						break;
					}
				}
				else
				{
					printf("超出棋盘范围,请重新输入\n");
				}
			}
			if (number == row * col - EASY_COUNT)
			{
				number = 0; // 游戏胜利,number重置为1
				return -1;
			}
				
			
		}
		else if (0 == goway)
		{
			printf("取消排雷\n");
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (goway);

}
  • 将雷的数量设置为79个即只有两个不是雷进行测试
  • 效果如下图:
    在这里插入图片描述

三、拓展棋盘功能

  • 此功能再排雷是判定选择的位置已经不是雷情况下执行。
  • 采用函数递归
    1. 如果这个位置周围没有雷,则这个位置可以为空格。
    1. 这个位置周围八个坐标没有排查过,排查过的位置直接跳过。
    1. 函数内部调用再次调用拓展函数,重新判断
    1. 如果满足继续排查
    1. 如果周围有雷,则停止排查,并将此位置显示周围雷的个数。

在这里插入图片描述

//game.c 源文件--ExtendBoard函数
// 拓展函数定义
void ExtendBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int x, int y)
{
	int count = BoomCount(mine, x, y);
	if (count == 0)
	{
		show[x][y] = ' ';
		int i = 0;
		for (i = -1; i <= 1; i++)
		{
			int j = 0;
			for (j = -1; j <= 1; j++)
			{
				if (i == j && 0 == j)
				{
					continue;
				}
				if (show[x + i][y + j] != '*')
				{
					continue;
				}
				ExtendBoard(show, mine, x + i, y + j);
			}
		}
	}
	else
	{
		show[x][y] = count + '0';
	}
	
}

这里只展示了一下拓展的效果。
拓展的效果如下图:
在这里插入图片描述

四、源码

1. test.c源文件

#include "game.h"
// 定义游戏菜单函数
void menu()
{
	printf("**********************\n");
	printf("*****   1. Play  *****\n");
	printf("*****   0. Quit  *****\n");
	printf("**********************\n");
}
void game()
{
	int choose = 0;
	int count = 0;
	int sum = 0;
	// 定义两个二维数组
	char mine[ROWS][COLS] = { 0 };
	char show[ROWS][COLS] = { 0 };

	// 初始化棋盘
	InitBoard(mine, ROWS, COLS, '0');
	InitBoard(show, ROWS, COLS, '*');

	// 布置雷
	SetBoard(mine, ROW, COL);

	// 打印棋盘
	//DisplayBoard(mine, ROW, COL);
	DisplayBoard(show, ROW, COL);

	// 玩家开始排雷
	do
	{
		printf("****************\n");
		printf("*** 1. 标记  ***\n");
		printf("*** 2. 排雷  ***\n");
		printf("*** 0. 退出  ***\n");
		printf("****************\n");
		printf("请选择:>");
		scanf("%d", &choose);

		if (1 == choose)
		{
			count = SignBoard(show, mine, ROW, COL);
			if (count != 0)
			{
				printf("恭喜你,排雷成功!!\n");
				break;
			}
		}
		else if (2 == choose)
		{
			//printf("排雷功能\n");
			sum = FineBoard(show, mine, ROW, COL);
			if (-1 == sum)
			{
				printf("恭喜你,排雷成功!!\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}
			else if (404 == sum)
			{
				printf("很遗憾,你被炸死了!\n");
				DisplayBoard(mine, ROW, COL);
				break;
			}

		}
		else if (0 == choose)
		{
			printf("退出游戏\n");
			break;
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (choose);

}
int main()
{
	int input = 0; // 定义输入菜单选项的变量
	srand((unsigned int)time(NULL));
	do
	{
		// 游戏菜单
		menu();
		printf("请选择:>");
		scanf("%d", &input);
		// 不同选择对应不同结果
		switch (input)
		{
		case 1:
			printf("扫雷游戏开始!!!\n");
			game();
			break;
		case 0:
			printf("退出游戏!!!\n");
			break;
		default:
			printf("选择错误,请重新输入\n");
			break; // 因为要重新输入所以从菜单开始循环
		}
	} while (input); // 输入为0退出游戏,同时停止循环
	return 0;
}

2. game.h头文件

#pragma once
#define  _CRT_SECURE_NO_WARNINGS

#include <stdio.h>
#include <stdlib.h>
#include <time.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 sign);


// 打印函数声明
void DisplayBoard(char board[ROWS][COLS], int row, int col);

// 布置雷函数声明
void SetBoard(char board[ROWS][COLS], int row, int col);

// 标记功能函数声明
int SignBoard(char show[ROWS][COLS],char mine[ROWS][COLS], int row, int col);

// 排雷函数声明
int FineBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col);

// 拓展函数声明
void ExtendBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int x, int y);

3. game.c源文件

#pragma once

#include "game.h"

// 初始化棋盘函数的定义
void InitBoard(char board[ROWS][COLS], int rows, int cols, char sign)
{
	int i = 0;
	for (i = 0; i < rows; i++)
	{
		int j = 0;
		for (j = 0; j < cols; j++)
		{
			board[i][j] = sign;
		}
	}
}


// 打印棋盘函数定义
void DisplayBoard(char board[ROWS][COLS], int row, int col)
{
	// 打印游戏开头分割线
	printf("-----扫雷游戏------\n");
	int i = 0;
	// 打印每一列数字
	for (i = 0; i <= row; i++)
	{
		printf("%d ", i); // 打印每一列数字
	}
	printf("\n");// 打印列数字完换行

	for (i = 1; i <= row; i++)
	{
		// 打印每一列数字之前先打印出行号
		printf("%d ", i);
		int j = 0;
		for (j = 1; j <= col; j++)
		{
			printf("%c ", board[i][j]);
		}
		printf("\n");
	}
	// 打印游戏结尾分割线
	printf("-----扫雷游戏------\n");
}


// 布置雷函数定义
void SetBoard(char board[ROWS][COLS], int row, int col)
{
	int count = EASY_COUNT;
	int x = 0;
	int y = 0;
	while (count)
	{
		x = rand() % row + 1;
		y = rand() % col + 1;
		if (board[x][y] == '0')
		{
			board[x][y] = '1';
			count--;
		}
	}
}



// 标记功能函数定义
int SignBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col)
{
	int x = 0;
	int y = 0;
	int choose = 0;
	static int sum = 0; // 定义标记的总数
	static int count = 0; // 定义标记的雷的总数
	do
	{
		printf("******************\n");
		printf("*** 1.标记位置 ***\n");
		printf("*** 2.取消标记 ***\n");
		printf("*** 0.不标记了 ***\n");
		printf("******************\n");
		printf("请选择:>");
		scanf("%d", &choose);

		if (1 == choose)
		{
			DisplayBoard(show, ROW, COL);
			printf("请输入标记坐标(空格隔开):>");
			scanf("%d %d", &x, &y);

			if (x >= 1 && x <= row && y >= 1 && y <= col) // 判断坐标合法性
			{
				if (show[x][y] == '*') // 判断坐标是否排查过
				{
					show[x][y] = '$';
					sum++; // 没标记一个加1
					if (mine[x][y] == '1')
					{
						count++; // 标记的位置如果是雷 加1
					}
				}
				else
				{
					printf("坐标已经被排查过了,请勿重复排查\n");
				}
			}
			else
			{
				printf("超出棋盘范围,请重新输入\n");
			}
			DisplayBoard(show, ROW, COL);
		}
		else if (2 == choose)
		{
			printf("请输入标记坐标(空格隔开):>");
			scanf("%d %d", &x, &y);

			if (x >= 1 && x <= row && y >= 1 && y <= col) // 判断坐标合法性
			{
				if (show[x][y] == '$') // 判断坐标是否标记过
				{
					show[x][y] = '*';
					sum--; // 没标记一个加1
					if (mine[x][y] == '1')
					{
						count--; // 标记的位置如果是雷 加1
					}
				}
				else
				{
					printf("坐标未被标记,请重新选择\n");
				}
			}
			else
			{
				printf("超出棋盘范围,请重新输入\n");
			}
			DisplayBoard(show, ROW, COL);
		}
		else if (0 == choose)
		{
			// 不标记直接跳转
			break;
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
		if (sum == count && count == EASY_COUNT)
		{
			sum = 0;
			count = 0;
			return EASY_COUNT;
		}
		else
		{
			return 0;
		}
	} while (choose);
}


// 计算周围雷的个数函数
int BoomCount(char board[ROWS][COLS], int x, int y)
{
	int i = 0;
	int sum = 0;

	for (i = -1; i <= 1; i++)
	{
		int j = 0;
		for (j = -1; j <= 1; j++)
		{
			if (i == j && 0 == j)
			{
				continue;
			}
			sum = sum +  board[x+i][y+j] - '0';
		}

	}
	return sum;
}



// 排雷函数声明
int FineBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int row, int col)
{
	int goway = 0;
	int x = 0;
	int y = 0;
	static int number = 0;
	do
	{
		printf("**************\n");
		printf("*** 1.排雷 ***\n");
		printf("*** 0.取消 ***\n");
		printf("**************\n");
		printf("请选择:>");
		scanf("%d", &goway);
		if (1 == goway)
		{
			DisplayBoard(show, ROW, COL);
			while (1)
			{
				printf("请输入排雷坐标(空格间隔):");
				scanf("%d %d", &x, &y);

				if (x >= 1 && x <= row && y >= 1 && y <= col) // 判断坐标合法性
				{
					if (show[x][y] == '*') // 判断是否被排查
					{
						if (mine[x][y] == '1')
						{
							return 404;
						}
						else
						{
							number++;
							// 调用计算周围雷个数的函数
							int bct = BoomCount(mine, x, y);
							if (bct == 0)
							{
								// 如果满足不是雷,并且周围没有雷的种种条件,则先调用拓展函数
								ExtendBoard(show, mine, x, y);
								DisplayBoard(show, ROW, COL);
								break;
							}
							else
							{
								show[x][y] = bct + '0';
								DisplayBoard(show, ROW, COL);
								break;
							}

						}

					}
					else
					{
						printf("此位置已经排查完,请勿重复排查\n");
						break;
					}
				}
				else
				{
					printf("超出棋盘范围,请重新输入\n");
				}
			}
			if (number == row * col - EASY_COUNT)
			{
				number = 0;
				return -1;
			}
				
			
		}
		else if (0 == goway)
		{
			printf("取消排雷\n");
		}
		else
		{
			printf("输入错误,请重新输入\n");
		}
	} while (goway);

}


// 拓展函数定义
void ExtendBoard(char show[ROWS][COLS], char mine[ROWS][COLS], int x, int y)
{
	int count = BoomCount(mine, x, y);
	if (count == 0)
	{
		show[x][y] = ' ';
		int i = 0;
		for (i = -1; i <= 1; i++)
		{
			int j = 0;
			for (j = -1; j <= 1; j++)
			{
				if (i == j && 0 == j)
				{
					continue;
				}
				if (show[x + i][y + j] != '*')
				{
					continue;
				}
				ExtendBoard(show, mine, x + i, y + j);
			}
		}
	}
	else
	{
		show[x][y] = count + '0';
	}
	
}

总结

C语言实现扫雷游戏的排雷菜单,以及功能的实现,拓展棋盘功能,以及源码等。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

第十五届蓝桥杯省赛第二场PythonB组B题【逆序对期望】题解(AC)

解题思路 枚举所有的可能的交换情况&#xff0c;时间复杂度 O ( n 4 ) O(n^4) O(n4)。 用归并排序计算数组的逆序对&#xff0c;时间复杂度 O ( n ) O(n) O(n)。 综上时间复杂度 O ( n 5 ) O(n^5) O(n5)。 由于 Python 运行效率较低&#xff0c;约 500 500 500 秒可得到…

前端框架技术调研

目前程序员使用前端框架最多的是哪一个&#xff1f;

SEGGER Embedded Studio IDE移植FreeRTOS

SEGGER Embedded Studio IDE移植FreeRTOS 一、简介二、技术路线2.1 获取FreeRTOS源码2.2 将必要的文件复制到工程中2.2.1 移植C文件2.2.2 移植portable文件2.2.3 移植头文件 2.3 创建FreeRTOSConfig.h并进行配置2.3.1 处理中断优先级2.3.2 configASSERT( x )的处理2.3.3 关于系…

echarts树图-实现拓扑图效果

使用echarts树图来实现拓扑图效果&#xff0c;其效果如下&#xff1a; 代码如下&#xff1a; const data {name: XXX公司,children: [{name: 网络主机,children: [{name: 普通路由器,children: [{name: 智能网关},{name: 192.168.1.0/24}]}]},{name: 企业路由器},{name: 三…

【分享】WinRAR软件如何压缩文件?

WinRAR是一款功能强大的压缩文件管理工具&#xff0c;支持多种压缩文件格式&#xff0c;那如何使用WinRAR来压缩文件呢&#xff1f;不清楚的小伙伴一起来看看吧&#xff01; 压缩方法&#xff1a; 首先&#xff0c;安装好WinRAR工具&#xff0c;然后选中需要压缩的文件或文件夹…

C++高级特性:异常概念与处理机制(十四)

1、异常的基本概念 异常&#xff1a;是指在程序运行的过程中发生的一些异常事件&#xff08;如&#xff1a;除数为0&#xff0c;数组下标越界&#xff0c;栈溢出&#xff0c;访问非法内存等&#xff09; C的异常机制相比C语言的异常处理&#xff1a; 函数的返回值可以忽略&…

麒麟龙芯loongarch64 electron 打包deb包

在麒麟龙芯&#xff08;loongarch64&#xff09;电脑上 使用electron 开发桌面应用。之前用electron-packager 打包出来的是文件夹 是 unpack 包。现在需要打包deb包&#xff0c;依据开发指南开始打包。 在项目文件夹下 打开终端 输入 npm run packager 先打包unpack包 然后…

FreeRTOS:3.消息队列

FreeRTOS消息队列 本文主要基于消息队列的源码进行分析&#xff0c;来对FreeRTOS的消息队列进一步学习。 消息队列非常重要&#xff0c;因为后面的各种信号量基本都是基于队列的&#xff0c;搞清楚消息队列的源码&#xff0c;也就搞清楚消息队列的原理。 参考链接&#xff1…

188页 | 2023企业数字化转型建设方案(数据中台、业务中台、AI中台)(免费下载)

1、知识星球下载&#xff1a; 如需下载完整PPTX可编辑源文件&#xff0c;请前往星球获取&#xff1a;https://t.zsxq.com/19KcxSeyA 2、免费领取步骤&#xff1a; 【1】关注公众号 方案驿站 【2】私信发送 【2023企业数字化转型建设方案】 【3】获取本方案PDF下载链接&#…

AI:165-Coze自定义赛博风格Bot-图片生成操作指南

Coze是由字节跳动推出的一个AI聊天机器人和应用程序编辑开发平台&#xff0c;旨在帮助用户快速创建各种类型的聊天机器人、智能体、AI应用和插件&#xff0c;并将其部署在社交平台和即时聊天应用程序中&#xff0c;如Discord、WhatsApp、Twitter、飞书、微信公众号等。 这个平…

计算机网络3——数据链路层3以太网的MAC层

文章目录 一、MAC 层的硬件地址1、介绍2、注意点3、定制标准 二、MAC 帧的格式1、结构2、工作原理3、其他 一、MAC 层的硬件地址 1、介绍 在局域网中&#xff0c;硬件地址又称为物理地址或 MAC地址(因为这种地址用在MAC帧中)。 大家知道&#xff0c;在所有计算机系统的设计中…

剑指Offer题目笔记32(拓扑排序)

面试题113&#xff1a; 解决方案&#xff1a; 将课程看成图中的节点&#xff0c;如果两门课程存在先修顺序那么它们在图中对应的节点之间存在一条从先修课程到后修课程的边&#xff0c;因此这是一个有向图。可行的修课序列实际上是图的拓扑排序序列。图中的每条边都是从先修课…

C++并发编程

基本介绍 线程 C98标准没有直接提供原生的多线程支持 在C98中&#xff0c;并没有像后来的C11标准中那样的<thread>库或其他直接的多线程工具 然而&#xff0c;这并不意味着在C98中无法实现多线程。开发者通常会使用平台特定的API&#xff08;如Windows的线程API或POSI…

前端开发攻略---用原生JS在网页中也能实现 文本转语音!

1、原理 语音合成 (也被称作是文本转为语音&#xff0c;英语简写是 tts) 包括接收 app 中需要语音合成的文本&#xff0c;再在设备麦克风播放出来这两个过程。 Web API中对此有一个主要控制接口 SpeechSynthesis&#xff0c;外加一些处理如何表示要被合成的文本 (也被称为 utte…

玩转微服务-SonarQube

这里写目录标题 第一节 SonarQube1.1 简介1.2 四个组成部分1.2.1 SonarQube服务器1.2.2 SonarQube数据库1.2.3 插件1.2.4 Scanner 1.3 工作流程 第二节 SonarQube的安装2.1 安装2.2 插件 第三节 P3C规范3.1 简介3.2 SonarQube 配置 P3C规范3.3 IDEA配置 P3C规范 第四节 Maven项…

机器学习-期末复习

本文的内容按照作者的课程考试要求书写&#xff0c;仅供复习参考。&#x1f337;&#x1f337;&#x1f337;欢迎大家指正&#xff01; 机器学习是一种人工智能&#xff08;AI&#xff09;的分支领域&#xff0c;它致力于开发能够通过数据学习和改进的算法和模型。简而言之&…

2024年AIGC+教育行业报告

在宏观层面上&#xff0c;如果把人工智能看作一种生命体&#xff0c;AIGC教育的内涵其实是碳基生命和硅基生命的 交互和培育问题。AIGC技术是对人脑计算、思考、判断等内在能力的延伸&#xff0c;是人的智能在机器形态 上的规模化聚集、运作和反应。由此&#xff0c;部分基础性…

【漏洞复现】云时空社会化商业ERP系统LoginName SQL注入漏洞

漏洞描述&#xff1a; 云时空社会化商业ERP系统loginName存在SQL注入漏洞&#xff0c;攻击者可以通过此漏洞获取数据库敏感信息。 搜索语法: Fofa-Query: app"云时空社会化商业ERP系统" 漏洞详情&#xff1a; 1.云时空社会化商业ERP系统。 2.漏洞POC&#xff1a…

倒计时开始!Big Demo Day第十二期,揭秘DePIN,探索Web3未来(附参会指南)

香港—— 全球领先的 Web3.0 活动 Big Demo Day 第十二期即将于 4 月 26 日在香港数码港盛大举行。本次活动由知名科技企业 ZeeprLabs 赞助&#xff0c;Central Research 主办&#xff0c;并得到 Techub News 的联合主办以及数码港、852Web3 等机构的合作支持。 在过去的 11 期…

鸿蒙HarmonyOS应用 - ArkUI组件

ArkUI组件 基础组件 Image 声明Image组件并设置图片源 网络权限&#xff1a;ohos.permission.INTERNET Image(scr: string | PixelMap | Resource)// 1. string&#xff1a;用于加载网络图片&#xff0c;需要申请网络权限 Image("https://xxx.png")// 2. PixelMap…