解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论

题目1、猜灯谜

题目描述

A 村的元宵节灯会上有一迷题:

请猜谜 * 请猜谜 = 请边赏灯边猜

小明想,一定是每个汉字代表一个数字,不同的汉字代表不同的数字。

请你用计算机按小明的思路算一下,然后提交“请猜谜”三个字所代表的整数即可。

请严格按照格式,通过浏览器提交答案。

注意:只提交一个3位的整数,不要写其它附加内容,比如:说明性的文字。

  1. public class Main {
  2. public static void main(String[] args) {
  3. // 从317开始,平方才能达到六位数
  4. for (int a = 3; a <= 9; a++) {
  5. for (int b = 0; b <= 9; b++) {
  6. if (a != b)
  7. for (int c = 0; c <= 9; c++) {
  8. int num = a * 100 + b * 10 + c;
  9. if (num > 316) {
  10. int num_num = num * num;
  11. int shiwan = num_num / 100000;
  12. int wan = num_num % 100000 / 10000;
  13. int shi = num_num % 100 / 10;
  14. int ge = num_num % 10;
  15. // 这里只需做几个标志性的判断,若结果出现多个(并不是很多就不用添加判断条件),再选择挑选符合要求的
  16. if (a == shiwan && b == ge && wan == shi) {
  17. System.out.println("" + a + b + c);
  18. System.exit(0);
  19. }
  20. }
  21. }
  22. }
  23. }
  24. }
  25. }

题目2、连续奇数和

题目描述

小明看到一本书上写着:任何数字的立方都可以表示为连续奇数的和。

比如:

2^3 = 8 = 3 + 5

3^3 = 27 = 7 + 9 + 11

4^3 = 64 = 1 + 3 + … + 15

虽然他没有想出怎么证明,但他想通过计算机进行验证。

请你帮助小明写出 111 的立方之连续奇数和表示法的起始数字。如果有多个表示方案,选择起始数字小的方案。

请严格按照要求,通过浏览器提交答案。

注意:只提交一个整数,不要写其它附加内容,比如:说明性的文字。

  1. public class Main {
  2. public static void main(String[] args) {
  3. int n = 111 * 111 * 111;
  4. int sum = 0;
  5. // 直接从1开始,枚举小于等于n的奇数相加
  6. for (int i = 1; i <= n; i += 2) {
  7. sum = 0;
  8. for (int j = i; j <= n; j += 2) {
  9. sum += j;
  10. if (sum > n)
  11. break;
  12. if (sum == n) {
  13. System.out.println(i);
  14. System.exit(0);
  15. }
  16. }
  17. }
  18. // 根据等差数列,an=2*n-1,Sn=n*n,根据这个来枚举
  19. for (int i = 1; i < 3000; i++) {
  20. for (int j = i; j < 3000; j++) {
  21. if (j * j - (i - 1) * (i - 1) == n) {
  22. System.out.println(2 * i - 1);
  23. System.exit(0);
  24. }
  25. }
  26. }
  27. }
  28. }

题目3、快速排序

  1. 题目描述
  2. 快速排序算法是典型的分治思想的运用。它使用某个key把全部元素分成两组,其中一组的元素不大于另一组。然后对这两组再次进行递归排序。
  3. 以下代码实现了快速排序。请仔细阅读代码,填写缺少代码的部分。
  4. static void f(int[] x, int left, int right)
  5. {
  6. if(left >= right) return;
  7. int key = x[(left+right)/2];
  8. int li = left;
  9. int ri = right;
  10. while(li<=ri){
  11. while(x[ri]>key) ri--;
  12. while(x[li]<key) li++;
  13. if(________________){ //填空位置
  14. int t = x[li];
  15. x[li] = x[ri];
  16. x[ri] = t;
  17. li++;
  18. ri--;
  19. }
  20. }
  21. if(li < right) f(x, li, right);
  22. if(ri > left) f(x, left, ri);
  23. }
  24. 请分析代码逻辑,并推测划线处的代码,通过网页提交。
  25. 注意:仅把缺少的代码作为答案,千万不要填写多余的代码、符号或说明文字!!
  26. li <= ri

题目4、九宫重排

题目描述

如图1的九宫格中,放着 1~8 的数字卡片,还有一个格子空着。与空格子相邻的格子中的卡片可以移动到空格中。经过若干次移动,可以形成图2所示的局面。

我们把图1的局面记为:12345678.

把图2的局面记为:123.46758

显然是按从上到下,从左到右的顺序记录数字,空格记为句点。

本题目的任务是已知九宫的初态和终态,求最少经过多少步的移动可以到达。如果无论多少步都无法到达,则输出-1。

例如:

输入数据为:

12345678.

123.46758

则,程序应该输出:

3

再如:

输入:

13524678.

46758123.

则,程序输出:

22

资源约定:

峰值内存消耗(含虚拟机) < 64M

CPU消耗 < 2000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意:不要使用package语句。不要使用jdk1.6及以上版本的特性。

注意:主类的名字必须是:Main,否则按无效代码处理。

  1. // 双广搜(起始位置分别为始态和终态)+康拓展开排重
  2. import java.util.Arrays;
  3. import java.util.LinkedList;
  4. import java.util.Scanner;
  5. public class Main {
  6. // 被访问过的为始态到该状态所需要的步数,未被访问过的为-1
  7. static int[] state1 = new int[362880];
  8. // 被访问过的为终态到该状态所需要的步数,未被访问过的为-1
  9. static int[] state2 = new int[362880];
  10. // 四行,分别表示空白格向上、下、左、右四个方向走
  11. static int[][] dir = { { 1, 0 }, { -1, 0 }, { 0, -1 }, { 0, 1 } };
  12. public static void main(String[] args) {
  13. Arrays.fill(state1, -1);
  14. Arrays.fill(state2, -1);
  15. Scanner sc = new Scanner(System.in);
  16. String start = sc.nextLine();
  17. String end = sc.nextLine();
  18. int ans = bfs(start, end);
  19. System.out.println(ans);
  20. sc.close();
  21. }
  22. public static int bfs(String start, String end) {
  23. LinkedList<Run> list1 = new LinkedList<Run>();
  24. LinkedList<Run> list2 = new LinkedList<Run>();
  25. list1.add(new Run(start, 0));
  26. list2.add(new Run(end, 0));
  27. while (!list1.isEmpty()) {
  28. Run head1 = list1.get(0);
  29. list1.remove(0);
  30. Run head2 = list2.get(0);
  31. list2.remove(0);
  32. int step1 = head1.step;
  33. if (head1.str.equals(end)) {
  34. return step1;
  35. }
  36. int step2 = head2.step;
  37. if (head2.str.equals(start)) {
  38. return step2;
  39. }
  40. char[][] ch1 = stringToArr(head1.str);
  41. int pointIndex1 = head1.str.indexOf('.');
  42. int pointX1 = pointIndex1 / 3;
  43. int pointY1 = pointIndex1 % 3;
  44. char[][] ch2 = stringToArr(head2.str);
  45. int pointIndex2 = head2.str.indexOf('.');
  46. int pointX2 = pointIndex2 / 3;
  47. int pointY2 = pointIndex2 % 3;
  48. for (int i = 0; i < dir.length; i++) {
  49. int nextX1 = pointX1 + dir[i][0];
  50. int nextY1 = pointY1 + dir[i][1];
  51. int nextX2 = pointX2 + dir[i][0];
  52. int nextY2 = pointY2 + dir[i][1];
  53. if (nextX1 >= 0 && nextX1 <= 2 && nextY1 >= 0 && nextY1 <= 2) {
  54. {
  55. char temp = ch1[pointX1][pointY1];
  56. ch1[pointX1][pointY1] = ch1[nextX1][nextY1];
  57. ch1[nextX1][nextY1] = temp;
  58. }
  59. String s = arrToString(ch1);
  60. if (state1[kangtuo(s)] == -1) {
  61. list1.addLast(new Run(s, step1 + 1));
  62. state1[kangtuo(s)] = step1 + 1;
  63. }
  64. if (state2[kangtuo(s)] != -1) {
  65. return step1 + 1 + state2[kangtuo(s)];
  66. }
  67. {
  68. char temp = ch1[pointX1][pointY1];
  69. ch1[pointX1][pointY1] = ch1[nextX1][nextY1];
  70. ch1[nextX1][nextY1] = temp;
  71. }
  72. }
  73. if (nextX2 >= 0 && nextX2 <= 2 && nextY2 >= 0 && nextY2 <= 2) {
  74. {
  75. char temp = ch2[pointX2][pointY2];
  76. ch2[pointX2][pointY2] = ch2[nextX2][nextY2];
  77. ch2[nextX2][nextY2] = temp;
  78. }
  79. String s = arrToString(ch2);
  80. if (state2[kangtuo(s)] == -1) {
  81. list2.addLast(new Run(s, step2 + 1));
  82. state2[kangtuo(s)] = step2 + 1;
  83. }
  84. if (state1[kangtuo(s)] != -1) {
  85. return step2 + 1 + state2[kangtuo(s)];
  86. }
  87. {
  88. char temp = ch2[pointX2][pointY2];
  89. ch2[pointX2][pointY2] = ch2[nextX2][nextY2];
  90. ch2[nextX2][nextY2] = temp;
  91. }
  92. }
  93. }
  94. }
  95. return -1;
  96. }
  97. // 康拓展开判重
  98. public static int kangtuo(String str) {
  99. int len = str.length();
  100. // 0~8的阶乘
  101. int[] fac = { 1, 1, 2, 6, 24, 120, 720, 5040, 40320 };
  102. // 存放由康拓展开计算出来的序数
  103. int sum = 0;
  104. int num = 0;
  105. for (int i = 0; i < len; i++) {
  106. num = 0;
  107. for (int j = i + 1; j < len; j++) {
  108. if (str.charAt(j) - '0' < str.charAt(i) - '0')
  109. num++;
  110. }
  111. sum += num * fac[len - 1 - i];
  112. }
  113. return sum;
  114. }
  115. // 将字符串转为二维数组
  116. public static char[][] stringToArr(String str) {
  117. char[][] a = new char[3][3];
  118. for (int i = 0; i < 3; i++) {
  119. for (int j = 0; j < 3; j++) {
  120. a[i][j] = str.charAt(i * 3 + j);
  121. }
  122. }
  123. return a;
  124. }
  125. // 将二维数组转为字符串
  126. public static String arrToString(char[][] a) {
  127. String s = "";
  128. for (int i = 0; i < a.length; i++) {
  129. s += new String(a[i]);
  130. }
  131. return s;
  132. }
  133. }
  134. // 他的实例存放着两个属性,一个String表示当前状态,一个step表示走到这个状态需要几步
  135. class Run {
  136. String str;
  137. int step;
  138. public Run(String str, int step) {
  139. this.str = str;
  140. this.step = step;
  141. }
  142. }

题目5、格子刷油漆

题目描述

X国的一段古城墙的顶端可以看成 2*N个格子组成的矩形(如图1所示),现需要把这些格子刷上保护漆。

你可以从任意一个格子刷起,刷完一格,可以移动到和它相邻的格子(对角相邻也算数),但不能移动到较远的格子(因为油漆未干不能踩!)

比如:a d b c e f 就是合格的刷漆顺序。

c e f d a b 是另一种合适的方案。

当已知 N 时,求总的方案数。当N较大时,结果会迅速增大,请把结果对 1000000007 (十亿零七) 取模。

输入数据为一个正整数(不大于1000)

输出数据为一个整数。

例如:

用户输入:

2

程序应该输出:

24

再例如:

用户输入:

3

程序应该输出:

96

再例如:

用户输入:

22

程序应该输出:

359635897

资源约定:

峰值内存消耗(含虚拟机) < 64M

CPU消耗 < 2000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意:不要使用package语句。不要使用jdk1.6及以上版本的特性。

注意:主类的名字必须是:Main,否则按无效代码处理。

  1. // 用Java这样写只能得到60%分数,但是用C语言这样写就满分
  2. import java.util.Scanner;
  3. public class Main {
  4. public static void main(String[] args) {
  5. final int MOD = 1000000007;
  6. Scanner sc = new Scanner(System.in);
  7. int n = sc.nextInt();
  8. if (n <= 0) {
  9. System.out.println(0);
  10. } else if (n == 1) {
  11. System.out.println(2);
  12. } else {
  13. long[] a = new long[n + 1];
  14. long[] b = new long[n + 1];
  15. a[1] = 1;
  16. a[2] = 6;
  17. b[1] = 1;
  18. for (int i = 2; i <= n; i++) {
  19. b[i] = (2 * b[i - 1]) % MOD;
  20. }
  21. for (int i = 3; i <= n; i++) {
  22. a[i] = (2 * a[i - 1] + b[i] + 4 * a[i - 2]) % MOD;
  23. }
  24. long ans = 4 * a[n] % MOD;
  25. for (int i = 2; i < n; i++) {
  26. ans += (8 * b[i - 1] * a[n - i] + 8 * b[n - i] * a[i - 1]) % MOD;
  27. ans %= MOD;
  28. }
  29. System.out.println(ans);
  30. }
  31. sc.close();
  32. }
  33. }

题目6、农场阳光

题目描述

X星球十分特殊,它的自转速度与公转速度相同,所以阳光总是以固定的角度照射。

最近,X星球为发展星际旅游业,把空间位置出租给Y国游客来晒太阳。每个租位是漂浮在空中的圆盘形彩云(圆盘与地面平行)。当然,这会遮挡住部分阳光,被遮挡的土地植物无法生长。

本题的任务是计算某个农场宜于作物生长的土地面积有多大。

输入数据的第一行包含两个整数a, b,表示某农场的长和宽分别是a和b,此时,该农场的范围是由坐标(0, 0, 0), (a, 0, 0), (a, b, 0), (0, b, 0)围成的矩形区域。

第二行包含一个实数g,表示阳光照射的角度。简单起见,我们假设阳光光线是垂直于农场的宽的,此时正好和农场的长的夹角是g度,此时,空间中的一点(x, y, z)在地面的投影点应该是(x + z * ctg(g度), y, 0),其中ctg(g度)表示g度对应的余切值。

第三行包含一个非负整数n,表示空中租位个数。

接下来 n 行,描述每个租位。其中第i行包含4个整数xi, yi, zi, ri,表示第i个租位彩云的圆心在(xi, yi, zi)位置,圆半径为ri。

要求输出一个实数,四舍五入保留两位有效数字,表示农场里能长庄稼的土地的面积。

例如:

用户输入:

10 10

90.0

1

5 5 10 5

程序应该输出:

21.46

再例如:

用户输入:

8 8

90.0

1

4 4 10 5

程序应该输出:

1.81

样例3:

用户输入:

20 10

45.0

2

5 0 5 5

8 6 14 6

程序输出:

130.15

资源约定:

峰值内存消耗(含虚拟机) < 64M

CPU消耗 < 2000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意:不要使用package语句。不要使用jdk1.6及以上版本的特性。

注意:主类的名字必须是:Main,否则按无效代码处理。

小编能力有限,还请大佬指点

第四届蓝桥杯JavaB组国(决)赛真题的更多相关文章

  1. 第六届蓝桥杯JavaB组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.分机号 X老板脾气古怪,他们公司的电话分机号都是3位数,老板规定,所有号码必须是降序排列,且不能有重复的数位.比如: 751,520, ...

  2. 第九届蓝桥杯JavaB组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.三角形面积 已知三角形三个顶点在直角坐标系下的坐标分别为: (2.3, 2.5) (6.4, 3.1) (5.1, 7.2) 求该三角 ...

  3. 第四届蓝桥杯JavaC组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.好好学习 汤姆跟爷爷来中国旅游.一天,他帮助中国的小朋友贴标语.他负责贴的标语是分别写在四块红纸上的四个大字:"好.好.学. ...

  4. 第三届蓝桥杯JavaB组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.数量周期 [结果填空](满分9分) 复杂现象背后的推动力,可能是极其简单的原理.科学的目标之一就是发现纷繁复杂的自然现象背后的简单法则 ...

  5. 第八届蓝桥杯JavaB组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.平方十位数 题目描述 由0~9这10个数字不重复.不遗漏,可以组成很多10位数字. 这其中也有很多恰好是平方数(是某个数的平方). 比 ...

  6. 第六届蓝桥杯JavaA组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.胡同门牌号 小明家住在一条胡同里.胡同里的门牌号都是连续的正整数,由于历史原因,最小的号码并不是从1开始排的. 有一天小明突然发现了有 ...

  7. 第六届蓝桥杯JavaC组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.机器人数目 少年宫新近邮购了小机器人配件,共有3类,其中, A类含有:8个轮子,1个传感器 B类含有: 6个轮子,3个传感器 C类含有 ...

  8. 第八届蓝桥杯JavaC组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.数位和 题目描述 数学家高斯很小的时候就天分过人.一次老师指定的算数题目是:1+2+-+100. 高斯立即做出答案:5050! 这次你 ...

  9. 第五届蓝桥杯JavaA组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.海盗分金币 有5个海盗,相约进行一次帆船比赛. 比赛中天气发生突变,他们被冲散了. 恰巧,他们都先后经过途中的一个无名的荒岛,并且每个 ...

随机推荐

  1. CSS:必须要掌握的重要基础知识点

    目录 1. 盒子 2. 常用选择器 3. 优先级 4. CSS继承 5. 伪元素(pseudo-element)和伪类(pseudo-class) 6. CSS:元素定位机制(positioning ...

  2. python 利用 for ... else 跳出双层嵌套循环

    背景 周末在写一个爬虫时,遇到这样一种场景:从搜索结果中下载指定数量的文件 例如:搜索结果中共分为10页展示,加起来一共50条数据,现在要做的是从50条数据中下载指定数量的数据 为了实现这个功能,开始 ...

  3. Loadrunner中遇到Failed to connect to server[10061] connection refused错误

    (1)run-time setting/browser emulation中,将simulate a new user on each iteration  选项去掉(默认是选中的). 重新运行一切正 ...

  4. java基础(反射,注解,多线程,juc)

    JAVA基础 java反射 class对象 三种方式获取class加载时对象 1.class.forName("全类名"):将字节码文件加载进内存,返回class对象 2.类名.c ...

  5. Spring Cloud Alibaba入门实战之nacos(一)

    Spring Cloud Alibaba入门实战之nacos(一) 前情介绍 ​ Spring Cloud Alibaba 是阿里巴巴提供的新一代的微服务解决方案,相信会有越来越多采用微服务架构的公司 ...

  6. mysql小白系列_07 锁与事务

    1.MySQL参数autocommit生产环境设1还是0?为什么? 2.MySQL参数tx_isolation生产环境上大多数是设什么值,为什么? 3.与MySQL锁相关的有哪些因素? 1.MySQL ...

  7. 博客管理与文章发布系统-第三方模块及其用法Part1

    写个帖子记录一下自己写的第一个express完整项目. 所需第三方模块及其用法. 一.先把所需文件和准备工作写一下 写项目前的准备 1.创建所需文件夹 public 静态资源 model 数据库操作 ...

  8. SSE系列内置函数中的shuffle函数

    SSE 系列内置函数中的 shuffle 函数 邮箱: quarrying@qq.com 博客: http://www.cnblogs.com/quarryman/ 发布时间: 2017年04月18日 ...

  9. (二)vue的生命周期及相关的运行流程

    @ 目录 1. vue的生命周期 经过一系列的初始化过程 需要设置数据监听 编译模板 将实例花在到DOM 并在数据变化时更新DOM 等 这是相应的生命周期函数 在用的时候直接写上, 其实很多人都这样, ...

  10. wordpress中文章发布时间不显示?用get_the_date代替the_date

    今天发现,在主题中部分地方使用the_date函数来显示文章发布的时间时,竟然发生不显示时间的情况,再仔细看了一下这些文章,有些都是经过几次修改和保存的,可能是由于the_date只是显示文章第一次发 ...