2024年十五届蓝桥杯省赛大学B组真题(Java完整版)

2024年十五届蓝桥杯省赛大学B组真题(Java)

前言:

赛后一直犹豫要不要对比赛进行复盘出个题解,拖到了现在,终于也是等到比赛结果出来,看到没有辜负个人期望成功取得省一,决定在国赛前对省赛进行一个复盘,顺带查漏补缺,总体而言,这次JavaB组的省赛题偏基础,没有太多的算法,也是延续了暴力杯的头衔,这次对数学的考察居然比以往提高了不少,令我感到意外,题外话不多说,让我们一起来复盘一下第十五届的省赛题吧,同时也祝愿各位能取得一个不错的成绩。
(未完篇)

试题A:报数游戏

本题总分:5 分

【问题描述】

在这里插入图片描述

【答案提交】

这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

答案:2429042904288

【解题思路】

该题数据量大,单纯靠电脑跑不太现实,那么其中肯定有数学规律在,通过计算可以得出 20 和 24 的最小公倍数是 120 ,再对符合条件的前四十个数进行输出,我们可以发现该规律是十次一循环,每次结尾都是 120 的倍数,那么我们可以求得第 202420242020 个数的值为 202420242020/10*120=2429042904240 ,再通过观察发现第四个数与上一个循环相差 48 ,把两个数值相加得到答案 2429042904288

【代码】

package SS2024b.baoshuyouxi;

public class Main {
	public static void main(String[] args) {
		long n = 202420242024L;
//		long count = 0;
//		for (long i = 1; count < 40; i++) {
//			if (i * 4 % 20 == 0 || i * 4 % 24 == 0) {
//				count++;
//				System.out.println(i * 4);
//			}
//		}
		long num1 = (n - 4) / 10 * 120;
		long num2 = 48;
		long num = num1 + num2;
		System.out.println(num);
	}
}

试题 B: 类斐波那契循环数

本题总分:5 分

【问题描述】

在这里插入图片描述

【答案提交】

这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一 个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

答案:7913837

【解题思路】

给出一个判断是否为类斐波那契循环数的判断式,该判断式类似于滚动窗口,固定取一个窗口大小,该大小为 n 的值,维护窗口内所有值的和 sum ,判断 sum 在小于等于 n 是是否存在相等的情况即可,从 1e7 开始一直递减遍历下去,遇到的第一个符合条件的数即为答案。

【代码】

package SS2024b.leifeibonaqixunhuan;

import java.util.ArrayList;

public class Main {
	public static void main(String[] args) {
		int l = (int) 1e7;
		while (l > 0) {
			if (isLei(l)) {
				System.out.println(l);
				break;
			}
			l--;
		}
	}

	static boolean isLei(int n) {
		boolean flag = false;
		int n1 = n;
		ArrayList<Integer> ys = new ArrayList<Integer>();
		while (n1 != 0) {
			ys.add(n1 % 10);
			n1 /= 10;
		}
		ArrayList<Integer> s = new ArrayList<Integer>();
		s.add(0);
		int sum = 0;
		for (int i = ys.size() - 1; i >= 0; i--) {
			s.add(ys.get(i));
			sum += ys.get(i);
		}

		int index = 0;
		while (sum <= n) {
			if (index != 0) {
				sum *= 2;
			}
			s.add(sum -= s.get(index++));
			if (sum == n) {
				flag = true;
				break;
			}
		}
		return flag;
	}
}

试题 C: 分布式队列

时间限制: 3.0s 内存限制: 512.0MB 本题总分:10 分

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述

【输出格式】

对于每一个 query 操作,输出一行,包含一个整数表示答案。

【样例输入】

3
add 1
add 2
query
add 1
sync 1
sync 1
sync 2
query
sync 1
query
sync 2
sync 2
sync 1
query

【样例输出】

0
1
1
3

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

该题只需要使用队列或者集合来模拟该操作过程以及掌握不断获取输入数据的操作,在每次进行查询操作时,输出最短的队列长度即为答案。

【代码】

package SS2024b.fenbushiduilie;

import java.util.ArrayList;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		ArrayList<Integer>[] list = new ArrayList[n];
		for (int i = 0; i < n; i++) {
			list[i] = new ArrayList<Integer>();
		}
		while (scan.hasNext()) {
			String cz = scan.next();
			if (cz.equals("add")) {
				int element = scan.nextInt();
				list[0].add(element);
			} else if (cz.equals("sync")) {
				int follower_id = scan.nextInt();
				if (list[0].size() != list[follower_id].size()) {
					list[follower_id].add(list[0].get(list[follower_id].size()));
				}

			} else if (cz.equals("query")) {
				int min = list[0].size();
				for (int i = 1; i < n; i++) {
					min = Math.min(min, list[i].size());
				}
				System.out.println(min);
			}
		}
		scan.close();
	}
}

试题 D: 食堂

时间限制: 3.0s 内存限制: 512.0MB 本题总分:10 分

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述

【输出格式】

输出共 q 行,每行一个整数表示对应输入数据的答案。

【样例输入】

2
3 0 1 0 1
0 2 2 1 1

【样例输出】

6
10

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

【代码】


试题 E: 最优分组

时间限制: 3.0s 内存限制: 512.0MB 本题总分:15 分

【问题描述】

在这里插入图片描述

【输入格式】

第一行,一个整数 N。
第二行,一个浮点数 p。

【输出格式】

输出一行,一个整数 K 表示答案。

【样例输入】

1000
0.05

【样例输出】

5

【样例说明】

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

本题是求解数学期望值,最大期望用试剂量为 N ,分成每组 k 只宠物后,生病概率为 1-(1-p) k ^k k ,固定要使用的试剂量为 n/k ,如果一组宠物生病的额外用试剂量为 k ,生病的总用试剂量为 k*[1-(1-p) k ^k k]n/k ,则总的期望用试剂量为 k[1-(1-p) k ^k k]*n/k+n/k 利用该式可求得最小期望值所代表的 k 。

【代码】

package SS2024b.zuiyoufenzu;

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		double p = scan.nextDouble();
		double min = 1.0 * n;
		int min_index = 1;
		for (int k = 1; k <= n; k++) {
			if (n % k == 0) {
				double num = k * (1 - Math.pow(1 - p, k)) * n / k + n / k;
				if (num < min) {
					min = num;
					min_index = k;
				}
			}
		}
		System.out.println(min_index);
		scan.close();
	}
}

试题 F: 星际旅行

时间限制: 3.0s 内存限制: 512.0MB 本题总分:15 分

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述

【输出格式】

输出共一行,一个浮点数(四舍五入保留两位小数)。

【样例输入】

3 2 3
1 2
2 3
2 1
2 0
1 1

【样例输出】

2.00

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

【代码】


试题 G: LITS游戏

时间限制: 3.0s 内存限制: 512.0MB 本题总分:20 分

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述

【输出格式】

对于每组数据,输出一行包含一个字符串。如果此组数据满足题意则输出“Yes”,否则输出 “No”。

【样例输入】

2
5
1 1 1 1 1
1 0 1 1 0
1 0 0 0 1
1 0 1 0 1
1 1 1 1 1
5
1 0 0 1 1
1 1 1 1 1
1 1 1 1 0
1 1 1 0 1
0 1 1 1 1

【样例输出】

No
Yes

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

【代码】


试题 H: 拼十字

时间限制: 3.0s 内存限制: 512.0MB 本题总分:20 分

【问题描述】

在这里插入图片描述

【输入格式】

第一行一个整数 N,表示有 N 个矩形。接下来 N 行,每行输入三个整数 l、w、c 表示一个矩形的长、宽和颜色。

【输出格式】

输出一个整数表示答案。由于答案可能会很大,所以你需要将答案对 1 0 9 10^9 109 + 7 取模之后输出。

【样例输入】

5
1 10 0
6 6 0
8 6 1
6 10 0
1 2 1

【样例输出】

2

【样例说明】

第 3 个矩形可以和第 1 个矩形拼十字,第 3 个矩形也可以和第 4 个矩形拼十字。所以一共有两对矩形可以拼十字,答案为 2。

【评测用例规模与约定】

对于 30% 的评测用例:1 ≤ N ≤ 5000。
对于 100% 的评测用例:1 ≤ N ≤ 1 0 5 10^5 105,1 ≤ l,w ≤ 1 0 5 10^5 105,0 ≤ c ≤ 2。

【解题思路】

【代码】


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

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

相关文章

【网络原理】UDP协议 | UDP报文格式 | 校验和 | UDP的特点 | 应用层的自定义格式

文章目录 一、UDP协议1.UDP的传输流程发送方接收方 2.UDP协议报文格式&#xff1a;长度受限校验和如何校验&#xff1a;CRC算法&#xff1a;循环冗余算法md5算法&#xff1a; 2.UDP的特点 二、开发中常见的自定义格式1.xml&#xff08;古老&#xff09;2.json&#xff08;最流行…

nn.TransformerEncoderLayer详细解释,使用方法!!

nn.TransformerEncoderLayer nn.TransformerEncoderLayer 是 PyTorch 的 torch.nn 模块中提供的一个类&#xff0c;用于实现 Transformer 编码器的一个单独的层。Transformer 编码器层通常包括一个自注意力机制和一个前馈神经网络&#xff0c;中间可能还包含层归一化&#xff…

uniapp关于iconfont字体图标使用

1、打开[阿里巴巴矢量图标库](https://www.iconfont.cn/)&#xff0c;选择需要的图标添加到购物车 2、点开购物车&#xff0c;将图标添加到项目 3、点开项目&#xff0c;点击下载至本地&#xff0c;会得到一个download.zip包 4、解压download包 5、将包里的iconfont.css和iconf…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-8.1--C语言LED驱动程序

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

Q1季度阿胶电商数据分析:某黑马品牌线上销售增长超1800%

作为滋补养三大宝之一&#xff0c;阿胶具有补血滋阴、润燥止血、益智健脑、缓延衰老、强筋健骨、提高免疫力等多种功效和作用。同时阿胶被誉为“补血神器”、“美容养颜”等&#xff0c;使得其备受市场欢迎。 根据鲸参谋数据显示&#xff0c;今年Q1季度&#xff0c;在综合电商…

【WEB前端2024】开源智体世界:乔布斯3D纪念馆-第15课-xcard方式跳转平行3D馆

【WEB前端2024】开源智体世界&#xff1a;乔布斯3D纪念馆-第15课-xcard方式跳转平行3D馆 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由JavaScript编写的智…

记录一次大数据量接口优化过程

问题描述 记录一次大数据量接口优化过程。最近在优化一个大数据量的接口&#xff0c;是提供给安卓端APP调用的&#xff0c;因为安卓端没做分批次获取&#xff0c;接口的数据量也比较大&#xff0c;因为加载速度超过一两分钟&#xff0c;所以导致接口超时的异常&#xff0c;要让…

【C++干货基地】探索C++模板的魅力:如何构建高性能、灵活且通用的代码库(文末送书)

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 引入 哈喽各位铁汁们好啊&#xff0c;我是博主鸽芷咕《C干货基地》是由我的襄阳家乡零食基地有感而发&#xff0c;不知道各位的…

天空卫士旗舰产品入选《网络安全专用产品指南》

权威认证 近日&#xff0c;中国网络安全产业联盟&#xff08;CCIA&#xff09;发布了第一版《网络安全专用产品指南》。这一权威指南中&#xff0c;天空卫士荣获殊荣&#xff0c;旗下三款尖端产品荣耀入选&#xff0c;分别是增强型Web安全网关&#xff08;ASWG&#xff09;、数…

广交会烹饪机器人用上大模型 支付宝小程序云提供技术支持

近日&#xff0c;第135届广交会正在火热进行&#xff0c;记者获悉&#xff0c;支付宝小程序云助力合作伙伴田螺云厨&#xff0c;在烹饪机器人上开始用上大模型技术。各类智能产品的亮相&#xff0c;从中国制造迈向中国创造&#xff0c;也成为广交会的一个亮点。 &#xff08;图…

ipad的文件如何传到手机里 iPad较大文件怎么发送出去 iMazing下载教程

在现代生活中&#xff0c;随着移动设备的普及和多样化&#xff0c;我们经常需要在不同设备之间传输文件&#xff0c;以便在工作、学习或娱乐中更加便捷地使用这些文件。iPad和iPhone是用户广泛使用的设备&#xff0c;我们时常使用它们来存储和访问大量的个人数据。但有时&#…

人脸识别开源算法库和开源数据库

目录 1. 人脸识别开源算法库 1.1 OpenCV人脸识别模块 1.2 Dlib人脸识别模块 1.3 SeetaFace6 1.4 DeepFace 1.5 InsightFace 2. 人脸识别开源数据库 2.1 CelebA 2.2 LFW 2.3 MegaFace 2.4 Glint360K 2.5 WebFace260M 人脸识别 (Face Recognition) 是一种基于人的面部…

C#命名空间常用函数

在C#中&#xff0c;不同命名空间下有各种常用函数&#xff0c;下面列举一些常见的函数及其对应的命名空间&#xff1a; System命名空间&#xff1a; Console.WriteLine()&#xff1a;用于向控制台输出信息。Convert.ToInt32()&#xff1a;用于将其他数据类型转换为整数类型。 S…

python与上位机开发day04

模块和包、异常、PyQt5 一、模块和包 1.1 模块 Python中模块就是一个.py文件&#xff0c;模块中可以定义函数&#xff0c;变量&#xff0c;类。模块可以被其他模块引用 1.1.1 导入模块 """ 导入格式1&#xff1a; import 模块名 使用格式&#xff1a; …

【百度Apollo】探索自动驾驶:Apollo 新版本 Beta 全新的Dreamview+,便捷灵活更丰富

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《linux深造日志》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 引入一、Dreamview介绍二、Dreamview 新特性2.1、基于模式的多场景——流程更简洁地图视角调节&#xff1a;调试流…

JavaEE技术之MySql高级(索引、索引优化、sql实战、View视图、Mysql日志和锁、多版本并发控制)

文章目录 1. MySQL简介2. MySQL安装2.1 MySQL8新特性2.2 安装MySQL2.2.1 在docker中创建并启动MySQL容器&#xff1a;2.2.2 修改mysql密码2.2.3 重启mysql容器2.2.4 常见问题解决 2.3 字符集问题2.4 远程访问MySQL(用户与权限管理)2.4.0 远程连接问题1、防火墙2、账号不支持远程…

Python中的类(Class)详解——新手指南

在Python编程中&#xff0c;类&#xff08;Class&#xff09;是一个非常重要的概念&#xff0c;它允许程序员创建自己的对象类型。这些对象类型可以包含数据&#xff08;称为属性&#xff09;和函数&#xff08;称为方法&#xff09;&#xff0c;它们定义了这些对象的行为。本文…

Spring-Mybatis-Xml管理(动态sql语句,sql语句复用)

目录 前置条件 动态SQL语句 动态删除数据 1.集合类型:数组 2.集合类型: List 型 SQL语句重用 说明 &#x1f9e8;前置条件 已经创建了实体类(这边举个例子) 实体类User表 表中的字段名User实体类的属性值id (bigint auto increment) 长整型 自动增长private Long iduser…

场景文本检测识别学习 day06(Vi-Transformer论文精读)

Vi-Transformer论文精读 在NLP领域&#xff0c;基于注意力的Transformer模型使用的非常广泛&#xff0c;但是在计算机视觉领域&#xff0c;注意力更多是和CNN一起使用&#xff0c;或者是单纯将CNN的卷积替换成注意力&#xff0c;但是整体的CNN 架构没有发生改变VIT说明&#x…

C++入门第二节

点赞关注不迷路&#xff01;&#xff0c;本节涉及c入门关键字、命名空间、输入输出... 1. C关键字 C总计63个关键字&#xff0c;C语言32个关键字 asmdoifreturntrycontinueautodoubleinlineshorttypedefforbooldynamic_castintsignedtypeidpublicbreakelselongsizeoftypenam…