当前位置:首页 » 《关注互联网》 » 正文

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

14 人参与  2024年05月11日 18:01  分类 : 《关注互联网》  评论

点击全文阅读


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 操作,输出一行,包含一个整数表示答案。

【样例输入】

3add 1add 2queryadd 1sync 1sync 1sync 2querysync 1querysync 2sync 2sync 1query

【样例输出】

0113

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

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

【代码】

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 行,每行一个整数表示对应输入数据的答案。

【样例输入】

23 0 1 0 10 2 2 1 1

【样例输出】

610

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

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

【代码】

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 表示答案。

【样例输入】

10000.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 31 22 32 12 01 1

【样例输出】

2.00

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

【代码】

试题 G: LITS游戏

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

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述

【输出格式】

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

【样例输入】

251 1 1 1 11 0 1 1 01 0 0 0 11 0 1 0 11 1 1 1 151 0 0 1 11 1 1 1 11 1 1 1 01 1 1 0 10 1 1 1 1

【样例输出】

NoYes

【样例说明】

在这里插入图片描述

【评测用例规模与约定】

在这里插入图片描述

【解题思路】

【代码】

试题 H: 拼十字

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

【问题描述】

在这里插入图片描述

【输入格式】

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

【输出格式】

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

【样例输入】

51 10 06 6 08 6 16 10 01 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://zhangshiyu.com/post/107121.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 祖母寿宴,侯府冒牌嫡女被打脸了(沈屿安秦秀婉)阅读 -
  • 《雕花锦年,昭都旧梦》(裴辞鹤昭都)完结版小说全文免费阅读_最新热门小说《雕花锦年,昭都旧梦》(裴辞鹤昭都) -
  • 郊区41号(许洛竹王云云)完整版免费阅读_最新全本小说郊区41号(许洛竹王云云) -
  • 负我情深几许(白诗茵陆司宴)完结版小说阅读_最热门小说排行榜负我情深几许白诗茵陆司宴 -
  • 九胞胎孕妇赖上我萱萱蓉蓉免费阅读全文_免费小说在线看九胞胎孕妇赖上我萱萱蓉蓉 -
  • 为保白月光,侯爷拿我抵了债(谢景安花田)小说完结版_完结版小说全文免费阅读为保白月光,侯爷拿我抵了债谢景安花田 -
  • 陆望程映川上官硕《我的阿爹是带攻略系统的替身》最新章节阅读_(我的阿爹是带攻略系统的替身)全章节免费在线阅读陆望程映川上官硕
  • 郑雅琴魏旭明免费阅读_郑雅琴魏旭明小说全文阅读笔趣阁
  • 头条热门小说《乔书意贺宴临(乔书意贺宴临)》乔书意贺宴临(全集完整小说大结局)全文阅读笔趣阁
  • 完结好看小说跨年夜,老婆初恋送儿子故意出车祸_沈月柔林瀚枫完结的小说免费阅读推荐
  • 热推《郑雅琴魏旭明》郑雅琴魏旭明~小说全文阅读~完本【已完结】笔趣阁
  • 《你的遗憾与我无关》宋怀川冯洛洛无弹窗小说免费阅读_免费小说大全《你的遗憾与我无关》宋怀川冯洛洛 -

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1