ブルーブリッジカップ31日間のスプリントパンチイン問題の解決策(24日目)

24日目

最初の質問

第11回2020ブルーブリッジカップ州選手権

ランニングワークアウト

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);
                    }
                }
            }
        }
    }
}

質問2

第12回ブルーブリッジカップ州選手権2021

直線

数日前にこの質問を書きましたが、説明は非常に詳細です。リンク:「BlueBridgeCup」直線(Java)

質問3

第11回2020ブルーブリッジカップ全国選手権

循環小数

Java研究生组第6题

それは少し難しいです、私はそれをしませんでした、私は青い橋ojプラットフォームコードを投稿しました。

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};
    }
}

質問4

2016年第7回ブルーブリッジカップ州選手権

カードの転置

C++C组第9题

bfs

最短の質問をbfsで検索します。これは、 AcWingの8つの数字を参照してください。

この質問の複雑な点は、1次元から2次元、2次元から1次元への添え字変換です。詳細については、コードとコメントを参照してください。

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) {
    
    
        Queue<String> q = new LinkedList<>();
        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);
    }
}

おすすめ

転載: blog.csdn.net/weixin_53407527/article/details/123908454