华为OD机试真题 Java 实现【挑选字符串】【2023 B卷 100分】,附详细解题思路

在这里插入图片描述

目录

    • 专栏导读
    • 一、题目描述
    • 二、输入描述
    • 三、输出描述
    • 四、解题思路
    • 五、Java算法源码
    • 六、效果展示

专栏导读

本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。
刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。

  • 专栏福利:限时订阅49.9,订阅后可加入华为OD刷题群,获得哪吒优先答疑机会(华为OD刷题指导,远程代码调试),群里大佬众多可以抱团取暖,群友刷题经验分享,考试经验分享。

在这里插入图片描述

一、题目描述

给定a-z,26个英文字母小写字符串组成的字符串A和B,其中A可能存在重复字母,B不会存在重复字母,现从字符串A中按规则挑选一些字母可以组成字符串B挑选规则如下:

  1. 同一个位置的字母只能挑选一次;
  2. 被挑选字母的相对先后顺序不能被改变

求最多可以同时从A中挑选多少组能组成B的字符串。

二、输入描述

输入为2行, 第一行输入字符串a,第二行输入字符串b,行首行尾没有多余空格。

三、输出描述

输出一行,包含一个数字表示最多可以同时从a中挑选多少组能组成b的字符串,行末没有多余空格

四、解题思路

  1. 读取输入的字符串A和B;
  2. 使用HashMap bMap 存储字符串B中每个字符的位置;
  3. 遍历字符串B,将每个字符及其位置存储在bMap中;
  4. 初始化大小为B长度的整型数组aArr,用于记录字符串A中每个字符出现的次数;
  5. 遍历字符串A,对于每个字符:
    • 如果字符存在于bMap中,即需要挑选的字符:
    • 获取该字符在字符串B中的位置indexInB;
    • 如果该字符是字符串B的第一个字符,或者其前一个字符的计数小于当前字符的次数:
    • 将当前字符在aArr中对应位置的计数加1;
  6. 输出aArr数组最后一个位置的计数,即最多可以同时从A中挑选多少组能组成B的字符串;

五、Java算法源码

public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    String A = in.nextLine();
    String B = in.nextLine();

    // 用 HashMap 存储字符在字符串 B 中的位置
    HashMap<Character, Integer> bMap = new HashMap<>();
    for (int i = 0; i < B.length(); i++) {
        bMap.put(B.charAt(i), i);
    }

    // 记录每个字符在字符串 A 中出现的次数
    int[] aArr = new int[B.length()];
    for (int i = 0; i < A.length(); i++) {
        if (bMap.containsKey(A.charAt(i))) {
            int indexInB = bMap.get(A.charAt(i));
            // 如果字符是字符串 B 的第一个字符,或者其前一个字符的计数小于当前字符的次数
            if (indexInB == 0 || aArr[indexInB] < aArr[indexInB - 1]) {
                // 将当前字符的次数加 1
                aArr[indexInB]++;
            }
        }
    }
    System.out.print(aArr[aArr.length - 1]);
}

六、效果展示

在这里插入图片描述


下一篇:华为OD机试真题 Java 实现【路灯照明问题】【2022Q4 100分】,感谢fly晨发现这个问题,并提供更优质的算法

本文收录于,华为OD机试(JAVA)真题(A卷+B卷)

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

你可能感兴趣的:(搬砖工逆袭Java架构师,华为od,java,华为,程序人生,学习)