蓝桥杯第三期模拟赛(java版)

📑前言

本文主要是【蓝桥杯第三期练习题】的文章,如果有什么需要改进的地方还请大佬指出⛺️

🎬作者简介:大家好,我是听风与他🥇
☁️博客首页:CSDN主页听风与他
🌄每日一句:狠狠沉淀,顶峰相见

目录

    • 📑前言
    • 第一题
      • 问题描述
      • 答案提交
      • 答案:6
    • 第二题
      • 问题描述
      • 答案提交
      • 答案:4186
    • 第三题
      • 问题描述
      • 答案提交
      • 答案:5503
    • 第四题
      • 问题描述
      • 答案提交
      • 答案:344
    • 第五题
      • 问题描述
      • 答案提交
      • 答案:171248
    • 第六题
      • 问题描述
    • 第七题
      • 问题描述
    • 第八题
      • 问题描述
    • 第九题
      • 问题描述
    • 第十题
      • 问题描述
    • 📑文章末尾

第一题

问题描述

请问 2023 有多少个约数?即有多少个正整数,使得 2023 是这个正整数的整数倍。

答案提交

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

public class Main {public static void main(String[] args) {// TODO Auto-generated method stubint count = 0;for(int i=1;i<=2023;i++) {if(2023%i==0) {count++;}}System.out.println(count);}}

答案:6

第二题

问题描述

请问有多少组整数对 l, r 满足:

1. l 和 r 都介于 0 (含)到 100 (含)之间;
  2. r-l >= 10。

答案提交

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

public class second {public static void main(String[] args) {// TODO Auto-generated method stubint ans = 0;for(int l=0;l<=100;l++) {for(int r=0;r<=100;r++) {if(r-l>=10) {ans++;}}}System.out.println(ans);}}

答案:4186

第三题

问题描述

只能被 1 和本身整除的数称为质数。
  请问在 1 (含)到 1000000 (含)中,有多少个质数的各个数位上的数字之和为 23 。
  提示:599 就是这样一个质数,各个数位上的数字之和为 5+9+9=23 。

答案提交

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

public class third {public static void main(String[] args) {// TODO Auto-generated method stubint ans=0;for(int i=2;i<=1000000;i++) {if (zhishu(i)&&(sumNum(i)==23)) {ans++;}}System.out.println(ans);}public static int sumNum(int n) {int ans = 0;while(n>0) {ans+=n%10;n=n/10;}return ans;}public static boolean zhishu(int n) {for(int i=2;i*i<=n;i++) {if(n%i==0) {return false;}}return true;}}

答案:5503

第四题

问题描述

求 12345678901234567890123456789012345678901234567890 除以 2023 的余数。

答案提交

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

import java.math.BigInteger;public class fouth {public static void main(String[] args) {// TODO Auto-generated method stubBigInteger num1 = new BigInteger("12345678901234567890123456789012345678901234567890");BigInteger num2 = new BigInteger("2023");System.out.println(num1.mod(num2));}}

答案:344

第五题

问题描述

对于一个 n 行 m 列的矩阵,它的一个 k 行 k 列的子矩阵是指由矩阵中的连续 k 行、连续 k 列组成的矩阵。
  子矩阵的和是指子矩阵中所有元素的和。现在,小蓝对于一个矩阵中的子矩阵中最大的子矩阵的和很感兴趣。
  例如,对于如下 3 行 4 列的矩阵,2 行 2 列的子矩阵的和的最大值是 8,对应的子矩阵为由最后两行最后两列组成的子矩阵。
  2 0 2 3
  1 1 0 1
  1 2 3 4
  现在,小蓝有一个 30 行 20 列的大矩阵,如下所示,请问它的 5 行 5 列的子矩阵的和的最大值是多少?
  9719 7515 5916 6467 7157 9614 8560 9075 2099 2838 1403 7652 6238 1699 8907 1804 5384 7942 7546 1978
  8785 1944 8108 6040 2010 6646 2750 5410 4516 8757 5624 9257 9030 9290 6833 4646 9749 5304 5633 1573
  8525 8244 8514 7474 7896 9731 8402 9036 1869 2688 2085 1667 7753 8466 4911 3812 8585 8319 4020 7350
  1949 9120 4424 4057 8277 4511 6333 1533 7624 8932 1053 8682 9284 4134 1466 3607 8753 5310 3728 4163
  9420 9185 7055 2342 4143 4499 2036 5374 7026 8638 8866 8364 1706 8767 1601 8309 5695 8179 4142 8489
  5876 5660 4658 8307 2582 7544 8793 8207 3979 1692 1400 1893 4500 6389 7198 4836 4761 6603 2859 1312
  6367 4174 9956 6668 6771 4795 6492 3937 7096 8041 8644 9379 8071 8667 5810 5794 8147 3823 7877 4822
  4809 3297 8518 4972 9754 6854 3271 7891 8882 1052 3197 6035 5628 7674 7931 8085 8970 7733 4745 8785
  7536 1511 6964 4763 5409 7032 8963 8576 3411 5853 3316 1267 7851 2735 6953 2970 1810 6830 5576 6903
  2241 1575 2379 4679 9519 9290 4802 1562 3509 8365 6777 5143 5610 1061 7880 1935 5793 7023 5629 9571
  2480 5937 4612 8890 1964 8532 3309 9737 8507 1849 8544 1500 9282 6288 2137 4730 4239 3473 4643 6377
  7341 2881 3430 5815 1972 6629 3817 4547 7561 4779 6578 6114 4972 5505 7515 1800 4784 2272 4502 7541
  7665 8607 2022 8192 2605 1346 4155 8725 8167 7022 6136 3615 6057 6329 8671 2033 3151 2249 5981 6412
  9046 3353 8650 6965 4179 1248 5659 5219 8083 5615 3821 4436 9217 7356 3914 5717 3734 3765 4435 7210
  8951 5013 2951 7401 2329 5686 6530 9581 6539 6881 8634 2663 2916 3019 8529 5645 8201 9270 1939 7275
  6429 1531 6322 9586 2793 7968 4001 9665 7624 4369 6245 5146 9567 6801 6064 6199 3210 6753 2586 7795
  5771 8507 7973 1470 1475 6896 6781 6572 8412 8557 8255 5268 8960 7251 9214 2489 6920 9917 3810 4605
  9116 7950 3715 1697 4703 2868 8673 3106 2579 1074 3992 3547 4279 3149 3396 6081 6221 1125 9358 2471
  8360 1526 4116 9278 6325 5175 5533 4107 7522 7599 7711 9211 1752 2431 8321 3844 3579 1047 3987 8487
  7600 2401 8748 8945 2078 1519 4614 4576 5706 4040 9358 1928 1327 6699 5258 2846 3418 8310 1249 3866
  7796 8668 4087 4258 8992 8996 4617 5997 2527 8204 8927 1456 9340 2088 1605 2299 9878 8347 7789 2122
  8372 1102 4243 4208 1651 7861 4947 7802 4704 6204 4455 6012 8494 9060 3747 2786 2136 1830 7424 8309
  6919 4420 2031 5399 2652 7219 4048 7013 5094 5276 4225 5976 4157 6722 8765 4679 1604 4986 5033 2623
  4015 2297 3067 6261 6623 4577 4589 4747 6659 7667 7853 4040 6393 9606 7219 9334 1316 3430 9963 5187
  4998 3735 9884 2990 1374 8436 6674 3018 5714 9352 8708 8789 7879 2965 1444 4671 4743 9817 6066 8057
  6996 9609 2884 4601 7287 3432 4145 8858 6857 8624 4531 6579 1615 2894 4521 3274 5237 1093 3317 9289
  7117 1850 3210 8010 2512 1394 4718 9332 5593 4118 4995 3994 5063 9426 1709 5128 4997 9287 1907 9068
  4258 7328 6490 2603 5333 5093 8070 2116 8489 1994 7098 7409 1463 4268 9509 2358 1192 2460 5031 6292
  4911 1192 1012 2494 5276 8981 3540 3306 8869 6678 7879 7526 8847 6270 7653 3109 6955 9760 8520 8673
  6328 7277 7818 3285 9398 4929 4639 1617 4023 1051 9320 4955 6580 6481 3824 9611 2863 6492 6281 6203

答案提交

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

public class fifth {
/*
答案:171248*/static int row = 30;static int col = 20;static int sub_size = 5;public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int matrix[][] = new int[row][col];int maxSum = Integer.MIN_VALUE;//读取矩阵for(int i=0;i<row;i++) {for(int j=0;j<col;j++) {matrix[i][j] = sc.nextInt();}}//查找最大子矩阵和for(int i=0;i<=row-sub_size;i++) {for(int j=0;j<=col-sub_size;j++) {int sum = check(matrix, i, j);maxSum = Math.max(maxSum, sum);}}//输出最大子矩阵和System.out.println(maxSum);}public static int check(int[][] matrix,int h,int l) {int sum = 0;for(int i=h;i<h+sub_size;i++) {for(int j=l;j<l+sub_size;j++) {sum += matrix[i][j];}}return sum;}}

答案:171248

第六题

问题描述

小蓝要上一个楼梯,楼梯共有 n 级台阶(即小蓝总共要走 n 级)。小蓝每一步可以走 1 级、2 级或 3 级台阶。
  请问小蓝至少要多少步才能上到楼梯顶端?

输入格式

输入一行包含一个整数 n 。

输出格式

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

样例输入

9

样例输出

3

样例输入

10

样例输出

4

评测用例规模与约定

对于所有评测用例,1 <= n <= 10000 。

import java.util.Scanner;public class sixth {public static void main(String[] args) {// TODO Auto-gene rated method stubScanner sc = new Scanner(System.in);int n = sc.nextInt();System.out.println(climb(n));}public static int climb(int n) {if(n<=3) {return n;}int num = n/3;if(n % 3 !=0) {num += 1;}return num;}
}

第七题

问题描述

给定一个仅包含数字字符的字符串,请统计一下这个字符串中出现了多少个值为奇数的数位。

输入格式

输入一行包含一个字符串,仅由数字字符组成。

输出格式

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

样例输入

123455

样例输出

4

样例输入

111222333111222333111222333

样例输出

18

评测用例规模与约定

对于所有评测用例,1 <= 字符数量 <= 10000 。

import java.util.Scanner;public class seventh {public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);String s = sc.next();char a[] = s.toCharArray();System.out.println(Sum(a));}public static int Sum(char[] a) {int ans = 0;for(int i=0;i<a.length;i++) {if(a[i]=='1'||a[i]=='3'||a[i]=='5'||a[i]=='7'||a[i]=='9') {ans++;}}return ans;}
}

第八题

问题描述

对于一个序列 a[1], a[2], …, a[n],如果 a[i] 满足 a[i]<a[i-1] 且 a[i]<a[i+1],则称 a[i] 是一个极小值,如果如果 a[i] 满足 a[i]>a[i-1] 且 a[i]>a[i+1],则称 a[i] 是一个极大值。
  给定一个序列,请找到极小值中最大的和极大值中最小的。

输入格式

输入的第一行包含一个整数 n ,表示序列的长度。
  第二行包含 n 个整数,相邻的整数之间使用一个空格分隔,表示给定的序列。

输出格式

输出一行包含两个整数,用一个空格分隔,分别表示极小值中最大的和极大值中最小的。输入保证至少存在一个极小值,至少存在一个极大值。

样例输入

8
1 8 2 4 4 3 5 3

样例输出

3 5

评测用例规模与约定

对于所有评测用例,1 <= n <= 1000,0 <= a[i] <= 10000。

import java.util.Scanner;public class eighth {public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int n = sc.nextInt();int min=Integer.MIN_VALUE,max=Integer.MAX_VALUE;int a[] = new int[n];for(int i=0;i<n;i++) {a[i] = sc.nextInt();}for(int i=1;i<n-1;i++) {if(a[i]<a[i-1]&&a[i]<a[i+1]) {min = Math.max(min, a[i]);}if(a[i]>a[i-1]&&a[i]>a[i+1]) {max = Math.min(max, a[i]);}}System.out.println(min+" "+max);}}

第九题

问题描述

对于一个字符矩阵,其中的一些字符构成字母 Y 是指存在一个中间字符,从这个中间字符向下、向左上(45度)、向右上(45度)的字符都与中间的字符相同。
  字母 Y 的长度指同时向 3 个方向的相同字母延伸的最大距离。
  例如,下图中所有的 1 组成一个字母 Y,长度为 3。
  又如,下图中以第 5 行第 6 列为中心也构成一个字母 Y (由字符 A 构成),长度为 1 。
  再如,下图中以第 4 行第 3 列为中心也构成一个字母 Y (由字符 0 构成),长度为 2 。
  1000001
  0100010
  0010100
  0001AAA
  00010A0
  00010A0
  00010A0
  给定一个字符矩阵,请找出能构成字母 Y 的最大长度,如果无法构成字母 Y,请输出 0 。

输入格式

输入的第一行包含两个整数 n, m ,用一个空格分隔,表示字符矩阵的行数和列数。
  接下来 n 行,每行包含 m 个字符,表示字符矩阵。

输出格式

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

样例输入

7 7
1000001
0100010
0010100
0001AAA
00010A0
00010A0
00010A0

样例输出

3

评测用例规模与约定

对于50%的评测用例,1 <= n, m <= 100。
  对于所有评测用例,1 <= n, m <= 1000,字符矩阵中仅包含数字字符和大写英文字母。

import java.util.Scanner;public class ninth {
/*
7 7
1000001
0100010
0010100
0001AAA
00010A0
00010A0
00010A0*/static int m;static int n;static char a[][];public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);n = sc.nextInt();m = sc.nextInt();sc.nextLine();//读取换行符a = new char[n][m];for(int i=0;i<n;i++) {a[i] = sc.nextLine().toCharArray();}int res=0;for(int i=1;i<n-1;i++) {for(int j=1;j<m-1;j++) {res = Math.max(res, max_num(i, j));}}System.out.println(res);}public static int max_num(int i,int j) {int temp = 0;//三个方向坐标的值int left_x=i-1,left_y=j-1;int right_x=i-1,right_y=j+1;int bottom_x=i+1;while(left_x>=0 && left_y>=0 && right_x>=0 && right_y<m && bottom_x<n  && a[i][j]==a[left_x][left_y]&& a[i][j]==a[right_x][right_y] && a[i][j]==a[bottom_x][j]) {//如果还有满足情况的条件,向三个方向延展,左上,右上,下面temp++;left_x--;left_y--;right_x--;right_y++;bottom_x++;}return temp;}}

第十题

问题描述

小蓝要上一个楼梯,楼梯共有 n 级台阶(即小蓝总共要走 n 级)。小蓝每一步可以走 a 级、b 级或 c 级台阶。
  请问小蓝总共有多少种方案能正好走到楼梯顶端?

输入格式

输入的第一行包含一个整数 n 。
  第二行包含三个整数 a, b, c 。

输出格式

输出一行包含一个整数,表示答案。答案可能很大,请输出答案除以 1000000007 后的余数。

样例输入

4
1 2 3

样例输出

7

样例输入

7
2 4 6

样例输出

0

评测用例规模与约定

对于 30% 评测用例,1 <= a < b < c <= n <= 50。
  对于 60% 评测用例,1 <= a < b < c <= n <= 1000。
  对于所有评测用例,1 <= a < b < c <= n <= 1000000。

import java.util.Scanner;public class tenth {public static void main(String[] args) {// TODO Auto-generated method stubScanner sc = new Scanner(System.in);int n = sc.nextInt();int a = sc.nextInt();int b = sc.nextInt();int c = sc.nextInt();System.out.println(climb(n, a, b, c));}public static int climb(int n,int a,int b,int c) {int dp[] = new int[n+1];int mod = 1000000007;dp[0]=1;for(int i=1;i<=n;i++) {if(i>=a) dp[i] = (dp[i]+dp[i-a])%mod;if(i>=b) dp[i] = (dp[i]+dp[i-b])%mod;if(i>=c) dp[i] = (dp[i]+dp[i-c])%mod;}return dp[n];}
}

📑文章末尾

在这里插入图片描述

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

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

相关文章

Java17 --- SpringCloud之Consul

目录 一、consul的使用 1.1、主要功能 1.2、安装及运行 1.3、添加微服务到consul 1.3.1、8001微服务添加相关pom、配置文件、注解 1.3.2、80微服务添加相关pom、配置文件、注解 1.4、三个注册中心异同 1.5、consul进行分布式配置 1.5.1、修改8001的yml配置文件 1.5.2…

map、set模拟(底层封装红黑树)

个人主页&#xff1a;Lei宝啊 愿所有美好如期而遇 前言 前面我们对红黑树进行了模拟实现&#xff1a; 现在我们将使用我们模拟的map和set对我们模拟的红黑树进行封装。 并且&#xff0c;本篇将增加红黑树的迭代器&#xff0c;模拟迭代器&#xff08;这里理解原理即可&…

重建大师模型构建精细网格失败是什么原因导致的呢?(如下图)

出现图中的报错一般是显存溢出、瓦块过大造成的。 重建大师是一款专为超大规模实景三维数据生产而设计的集群并行处理软件&#xff0c;输入倾斜照片&#xff0c;激光点云&#xff0c;POS信息及像控点&#xff0c;输出高精度彩色网格模型&#xff0c;可一键完成空三、自动建模和…

flex弹性盒子实现左中右居中布局

1、效果展示 2、布局与样式 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>测试弹性盒子</title> </head> <body> <div class"out-parent"><div class"…

计算机网络 —— 运输层

运输层 5.1 运输层概述 运输层的主要任务是&#xff0c;如何为运行在不同主机上的应用进程提供直接的通信服务。运输层协议又称为端到端协议。 根据应用需求的不同&#xff0c;因特网的运输层为应用层提供了两种不同的运输协议&#xff0c;即面向连接的TCP和无连接的UDP 5.2…

Vant中<van-button>中icon的位置设置

一般在<van-button>按钮中加入icon&#xff0c;其位置都在左侧 我们可以用&#xff1a;van-position&#xff0c;改变图标展示位置 如&#xff1a;icon-position"right"

【30天】Python从入门到精通详解版—第一天—Python编程语言简介

Python编程语言简介 Python 简介Python 发展历史Python 特点Python 环境搭建Python下载Python安装环境变量配置在 Unix/Linux 设置环境变量在 Windows 设置环境变量 运行Python Python 简介 Python是一种高级编程语言&#xff0c;由Guido van Rossum于1989年底发明。Python在设…

React入门 学习全记录(适合和我一样有Vue经验想学习react的同学~)

前端目前的三大框架&#xff1a;Vue、React、Angular比较 都采用了组件化开发的方式&#xff0c;都是基于MVVM的框架有着虚拟DOM&#xff0c;Vue 和 Angular 都采用了响应式设计的方式&#xff0c;当数据发生变化时会自动更新视图。React 和 Angular 的复杂性也使得它们更加适…

MongoDB黑窗口操作(CRUD)

目录 连接数据库 插入数据 for循环插入数据 根据条件查询 修改数据 删除数据 连接数据库 对应路径下cmd中输入命令mongo即可 插入数据 j{name:"mongo"} t{x:3} 提交&#xff1a;db.things.svae(j);db.things.svae(t); 查询&#xff1a;db.things.find(); …

Java后端八股文之java基础

文章目录 0.Java 中有 8 种基本数据类型1. 为什么浮点数运算会丢失精度&#xff1f;如何解决&#xff1f;2. 面向对象的三大特征2.1 封装2.2 继承2.3 多态 3. 深拷贝和浅拷贝的区别&#xff1f;什么是引用拷贝&#xff1f;4. equals方法与“”方法4.1 4.2 equals方法 5.hashcod…

数据分析之一些Excel函数

数据分析之Excel的使用 SUM()求和SUMIF()单条件求和SUMIFS()多条件求和日期函数YEAR()提取年份MONTH()提取月份DAY()提取日DATE()函数 SUBTOTAL()求和IF()函数IF嵌套 VLOOKUP()搜索取值MATCH()返回行值或列值INDEX()定位取值 SUM()求和 SUM(number1,[number2],…) 对选中的区域…

00后卷王自述,我真的很卷。。。

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 前段时间去面试了一个公司&#xff0c;成功拿到了offer&#xf…