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

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

本题是求最大满足人数,一开始我想到的是背包问题求解,测试用例只通过了三个,后来发现题目数据量较小,可以直接进行枚举求解,尝试了好几回,一样是只通过三个测试用例,暂时出不了这题的题解,只能先发一下代码,希望各位大佬能帮忙纠正一下

【代码】

package SS2024b.shitang;import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scan = new Scanner(System.in);int q = scan.nextInt();while (q-- > 0) {int a2 = scan.nextInt();int a3 = scan.nextInt();int a4 = scan.nextInt();int b4 = scan.nextInt();int b6 = scan.nextInt();int sum = 0;// 优先分配四人桌if (b4 != 0) {// 四人寝int num_4 = 0;if (b4 != 0 && a4 != 0) {// 获取最多可以分配的四人桌数量int count = Math.min(a4, b4);num_4 = count * 4;a4 -= count;b4 -= count;}// 两人寝*2int num_22 = 0;if (b4 != 0 && a2 != 0 && a2 / 2 != 0) {// 获取最多可以分配的四人桌数量int count = Math.min(a2 / 2, b4);num_22 = count * 4;a2 -= count * 2;b4 -= count;}// 三人寝int num_3 = 0;if (b4 != 0 && a3 != 0) {// 获取最多可以分配的四人桌数量int count = Math.min(a3, b4);num_3 = count * 3;a3 -= count;b4 -= count;}// 两人寝int num_2 = 0;if (b4 != 0 && a2 != 0) {// 获取最多可以分配的四人桌数量int count = Math.min(a2, b4);num_2 = count * 2;a2 -= count;b4 -= count;}sum += num_4 + num_22 + num_3 + num_2;}// 贪心分配剩下的六人桌if (b6 != 0) {// 四人寝+两人寝室int num_42 = 0;if (b6 != 0 && a4 != 0 && a2 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a4, Math.min(a2, b6));num_42 = count * 6;b6 -= count;a2 -= count;a4 -= count;}// 三人寝*2int num_33 = 0;if (b6 != 0 && a3 != 0 && a3 / 2 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a3 / 2, b6);num_33 = count * 6;b6 -= count;a3 -= count * 2;}// 两人寝*3int num_222 = 0;if (b6 != 0 && a2 != 0 && a2 / 3 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a2 / 3, b6);num_222 = count * 6;b6 -= count;a2 -= count * 3;}// 三人寝+两人寝int num_32 = 0;if (b6 != 0 && a3 != 0 && a2 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a3, Math.min(a2, b6));num_32 = count * 5;b6 -= count;a2 -= count;a3 -= count;}// 四人寝int num_4 = 0;if (b6 != 0 && a4 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a4, b6);num_4 = count * 4;b6 -= count;a4 -= count;}// 两人寝*2int num_22 = 0;if (b6 != 0 && a2 != 0 && a2 / 2 != 0) {int count = Math.min(a2 / 2, b6);num_22 = count * 4;b6 -= count;a2 -= count * 2;}// 三人寝int num_3 = 0;if (b6 != 0 && a3 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a3, b6);num_3 = count * 3;b6 -= count;a3 -= count;}// 两人寝int num_2 = 0;if (b6 != 0 && a2 != 0) {// 获取最多可以分配的六人桌数量int count = Math.min(a2, b6);num_2 = count * 2;b6 -= count;a2 -= count;}sum += num_42 + num_33 + num_222 + num_32 + num_4 + num_22 + num_3 + num_2;}System.out.println(sum);}scan.close();}
}

试题 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。

【解题思路】

【代码】


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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 Python 代码实现 ICMP Timestamp 请求和回应

前言 ICMP&#xff08;Internet Control Message Protocol&#xff09;是在IP网络上传输控制消息的协议。其中&#xff0c;ICMP Timestamp请求和回应是ICMP协议中的一种消息类型&#xff0c;用于获取和同步网络设备的时间戳信息。 ICMP Timestamp请求和回应的工作原理如下&am…

STM32与Proteus的串口仿真详细教程与源程序

资料下载地址&#xff1a;STM32与Proteus的串口仿真详细教程与源程序 资料内容 包含LCD1602显示&#xff0c;串口发送接收&#xff0c;完美实现。 文档内容齐全&#xff0c;包含使用说明&#xff0c;相关驱动等。 解决了STM32的Proteus串口收发问题。 注意&#xff1a;每输…

【酱浦菌-爬虫项目】爬取百度文库文档

1. 首先&#xff0c;定义了一个变量url&#xff0c;指向百度文库的搜索接口 ‘https://wenku.baidu.com/gsearch/rec/pcviewdocrec’。 2. 然后&#xff0c;设置了请求参数data&#xff0c;包括文档ID&#xff08;docId&#xff09;和查询关键词&#xff08;query&#xff09;。…

debian gnome-desktop GUI(图形用户界面)系统

目录 &#x1f31e;更新 &#x1f3a8;安装 &#x1f34e;分配 &#x1f6cb;️重启 &#x1f511;通过VNC连接 debian gnome-desktop &#x1f31e;更新 sudo apt update sudo apt -y upgrade &#x1f3a8;安装 sudo apt -y install task-gnome-desktop 这个过程比…

【HTTP协议】了解http需要学习哪些内容

HTTP&#xff08;Hypertext Transfer Protocol&#xff09;是超文本传输协议&#xff0c;互联网上应用最广泛的一种协议&#xff0c;它负责在客户端和服务器之间传输数据。本文将从HTTP协议的基本原理、请求-响应模型、常见特性以及应用场景等方面进行总结。 1. HTTP基本原理 …

WordPress缓存插件有哪些?好用的缓存插件分享

目前WordPress缓存插件有&#xff1a;WP Rocket、WP Super Cache、W3 Total Cache、Sucuri、NitroPack、SiteGround Optimizer、LiteSpeed Cache、WP-Optimize、Hummingbird、Cache Enabler、Comet Cache。 在当今的数字世界中&#xff0c;拥有一个高效的网站对于吸引和留住用…

智慧农场系统 搭建重点,会用到哪些三方服务?

智慧农场小游戏的搭建重点主要集中在游戏设计、用户体验、数据安全和稳定性等方面。为了实现这些目标&#xff0c;可能会用到以下第三方服务&#xff1a; 游戏引擎和开发工具&#xff1a;使用成熟的游戏引擎和开发工具可以极大地简化开发流程&#xff0c;提高开发效率。例如&a…

Node+Express连接mysql实现增删改查

还是大剑师兰特&#xff1a;曾是美国某知名大学计算机专业研究生&#xff0c;现为航空航海领域高级前端工程师&#xff1b;CSDN知名博主&#xff0c;GIS领域优质创作者&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;canvas&#xff0c;webgl&#xff0c;ech…

GhostNetV3 论文学习

论文地址&#xff1a;https://arxiv.org/abs/2404.11202 代码地址&#xff1a;https://github.com/huawei-noah/Efficient-AI-Backbones 解决了什么问题&#xff1f; 对于边端设备&#xff0c;人们特别设计了一些精简的神经网络&#xff0c;这些网络推理速度更快、表现适中。…

C++并发编程

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

【C/C++】动态内存管理(C:malloc,realloc,calloc,free || C++:new,delete)

&#x1f525;个人主页&#xff1a; Forcible Bug Maker &#x1f525;专栏&#xff1a; C | | C语言 目录 前言C/C内存分布C语言中的动态内存管理&#xff1a;malloc/realloc/realloc/freemallocrealloccallocfree C中的动态内存管理&#xff1a;new/deletenew和delete操作内…

微信小程序:9.小程序配置

全局配置文件 小程序根目录下的app.json文件是小程序的全局配置文件。 常用的配置文件如下: pages 记录当前小程序所有的页面存放路径信息 window 全局设置小程序窗口外观 tabBar 设置小程序底部的tabBar效果 style 是否启用新版style 小程序窗口的组成部分 了解windo节点常…

HTTP:强缓存优化实践

强缓存&#xff1a;浏览器不会向服务器发送任何请求&#xff0c;直接从本地缓存中读取文件 强缓存是指浏览器在向服务器请求资源时&#xff0c;判断本地是否存在该资源的缓存&#xff0c;并判断是否过期。 如果本地缓存未过期&#xff0c;浏览器就直接使用本地缓存&#xff0c…

element 分页切换时:current-page无效 页数不会跟着一起切换

问题回溯&#xff1a;使用el-pagination组件 选择切换当前分页 页数为2 问题结果&#xff1a;el-pagination组件 当前页切换失败 一直都是 1&#xff0c;接口传参分页数据是2&#xff0c;打印当前分页也是2 解决方案1&#xff1a;使用 current-page参数 .sync 修饰符 解决方案2…

微信小程序简单实现购物车功能

微信小程序简单实现购物车结算和购物车列表展示功能 实现在微信小程序中对每一个购物车界面的商品订单&#xff0c;进行勾选结算和取消结算的功能&#xff0c;相关界面截图如下&#xff1a; 具体实现示例代码为&#xff1a; 1、js代码&#xff1a; Page({/*** 页面的初始数…

清理电脑垃圾软件

清理电脑垃圾软件 1.geek.exe 强力卸载 2. 磁盘分析 直接删除 log 磁盘文件大小分析工具WizTree_v4.01

TCP相关问题总结

文章目录 TCP连接建立过程1. TCP三次握手2. TCP四次挥手3. TCP为什么是三次握手4. TCP为什么是四次挥手 TCP流量控制TCP拥塞控制1. 为什么需要拥塞控制2. 控制手段 TCP连接建立过程中出现丢包 TCP连接建立过程 1. TCP三次握手 首先client端发出连接请求&#xff0c;并且请求同…

paddle ocr模型量化实践

参考&#xff1a;https://github.com/PaddlePaddle/PaddleOCR/blob/main/deploy/slim/quantization/README.md https://github.com/PaddlePaddle/PaddleOCR/blob/release/2.7.1/doc/doc_ch/FAQ.md 蒸馏 剪枝 量化 参考&#xff1a;https://blog.csdn.net/mddCSDN/article/de…

高扬程水泵,提升水源新选择!— 恒峰智慧科技

在炎炎夏日&#xff0c;阳光炙烤着大地&#xff0c;森林火灾的发生频率也随之上升。火势猛烈&#xff0c;烟雾弥漫&#xff0c;给森林带来了极大的破坏。为了保护森林资源&#xff0c;我们必须采取有效的措施来扑灭火灾。而在这其中&#xff0c;高扬程水泵成为了提升水源新选择…

一种基于YOLOv8改进的高精度红外小目标检测算法 (原创自研)

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文摘要&#xff1a;一种基于YOLOv8改进的高精度小目标检测算法&#xff0c; 在红外小目标检测任务中实现暴力涨点&#xff1b; &#x1f4a1;&#x1f4a1;&#x1f4a1;创新点&#xff1a; 1&#xff09;SPD-Conv特别是在处理低分…