目录
- 专栏导读
- 一、题目描述
- 二、输入描述
- 三、输出描述
- 四、解题思路
- 五、Java算法源码
- 六、效果展示
专栏导读
本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。
刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。
- 专栏福利:限时订阅49.9,订阅后可加入华为OD刷题群,获得哪吒优先答疑机会(华为OD刷题指导,远程代码调试),群里大佬众多可以抱团取暖,群友刷题经验分享,考试经验分享。
一、题目描述
给定a-z,26个英文字母小写字符串组成的字符串A和B,其中A可能存在重复字母,B不会存在重复字母,现从字符串A中按规则挑选一些字母可以组成字符串B挑选规则如下:
- 同一个位置的字母只能挑选一次;
- 被挑选字母的相对先后顺序不能被改变
求最多可以同时从A中挑选多少组能组成B的字符串。
二、输入描述
输入为2行, 第一行输入字符串a,第二行输入字符串b,行首行尾没有多余空格。
三、输出描述
输出一行,包含一个数字表示最多可以同时从a中挑选多少组能组成b的字符串,行末没有多余空格
四、解题思路
- 读取输入的字符串A和B;
- 使用HashMap bMap 存储字符串B中每个字符的位置;
- 遍历字符串B,将每个字符及其位置存储在bMap中;
- 初始化大小为B长度的整型数组aArr,用于记录字符串A中每个字符出现的次数;
- 遍历字符串A,对于每个字符:
- 如果字符存在于bMap中,即需要挑选的字符:
- 获取该字符在字符串B中的位置indexInB;
- 如果该字符是字符串B的第一个字符,或者其前一个字符的计数小于当前字符的次数:
- 将当前字符在aArr中对应位置的计数加1;
- 输出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在线答疑。