# 蓝桥杯31天冲刺打卡题解（Day24）

22 篇文章 11 订阅

## Day24

### 第一题

#### 跑步锻炼

C++B组第4题

填空题

public class Main {
public static void main(String[] args) {
int[] days = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31} ;
int week = 6; // 2020年1月1日是星期六
int cnt = 0; // 公里数
for (int year = 2000; year <= 2020; year++) {
if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) days[2] = 29;
else days[2] = 28;
for (int month = 1; month <= 12; month++) {
for (int day = 1; day <= days[month]; day++) {
cnt++; // 正常跑1千米
if (week == 8) week = 1; // 回归星期一
if (week == 1 || day == 1) cnt++; // 多跑1千米
week++; // 进入第二天
if (year == 2020 && month == 10 && day == 1) {
System.out.println(cnt);
}
}
}
}
}
}


### 第三题

#### 循环小数

Java研究生组第6题

import java.util.Scanner;
import java.math.BigInteger;

public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int p = scanner.nextInt();
int q = scanner.nextInt();
int pre = scanner.nextInt();
double x = pre * 1.0 / Math.pow(10, String.valueOf(pre).length());
double nx = x * Math.pow(10, q - p + 1);
x = Double.parseDouble(String.valueOf(x).substring(0, p + 1));
double num = nx - x;
// 把num转为分数
int[] fenshu = float2FenShu(num);
fenshu = getFinalFenshu(fenshu, (int) (Math.pow(10, q - p + 1) - 1));
System.out.println(fenshu[0] + " " + fenshu[1]);
}
// 得到最后的分数
private static int[] getFinalFenshu(int[] fenshu, int i) {
// 分母首先得乘i
int up = fenshu[0];
int down = fenshu[1] * i;
// 分子分母最简
BigInteger a = BigInteger.valueOf(up);
BigInteger b = BigInteger.valueOf(down);
int gcd = a.gcd(b).intValue();
up /= gcd;
down /= gcd;
return new int[]{up, down};
}

public static int[] float2FenShu(double num) {
String s = String.valueOf(num);
int cnt = 0;
for (char c : s.toCharArray()) {
cnt++;
if (c == '.') {
break;
}
}
int subFloat = s.length() - cnt; // 表示后面小数位数
// 分子
int up = (int) (num * Math.pow(10, subFloat));
// 分母
int down = (int) Math.pow(10, subFloat);
return new int[] {up, down};
}
}


### 第四题

#### 卡片换位

C++C组第9题

bfs

import java.util.*;

public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String start = "";
int a_start = 0, b_start = 0;
for (int i = 0; i < 2; i++) {
start += sc.nextLine();
for (int j = 0; j < 3; j++){
char c = start.charAt((i * 3) + j);
if (c == 'A') a_start = i * 3 + j; // A初始坐标
if (c == 'B') b_start = i * 3 + j; // B初始坐标 二维转换为一维
}
}

System.out.println(bfs(start, a_start, b_start));
}

private static int bfs(String start, int a_start, int b_start) {
Map<String, Integer> map = new HashMap(); // 用map存储 key是每个字符串的状态 value是操作的次数
q.offer(start);
map.put(start, 0);

int[] dx = {0, 1, 0, -1}, dy = {1 ,0, -1, 0};
while (!q.isEmpty()) {
String t = q.poll();
int distance = map.get(t);

if (t.indexOf('B') == a_start && t.indexOf('A') == b_start) return distance; // 交换成功

int k = t.indexOf(" "); // 找到空格下标
int x = k / 3, y = k % 3; // 将一维转换为二维下标
for (int i = 0; i < 4; i++) {
int a = x + dx[i], b = y + dy[i];
if (a < 0 || a >= 2 || b < 0 || b >= 3) continue;
String s = swap(t, k, a * 3 + b); // 交换下标
if (map.get(s) == null){ // 表示还没出现过这个状态
map.put(s, distance + 1); // 距离+1
q.offer(s);
}
}
}
return -1;
}

private static String swap(String s, int i, int j){
char[] c = s.toCharArray();
char ch = c[i];
c[i] = c[j];
c[j] = ch;
return new String(c);
}
}

• 19
点赞
• 4
收藏
觉得还不错? 一键收藏
• 打赏
• 4
评论
06-23 399
06-20 775
06-21 139

### “相关推荐”对你有帮助么？

• 非常没帮助
• 没帮助
• 一般
• 有帮助
• 非常有帮助

¥1 ¥2 ¥4 ¥6 ¥10 ¥20

1.余额是钱包充值的虚拟货币，按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载，可以购买VIP、付费专栏及课程。