本专栏收录于《华为OD机试(JAVA)真题(A卷+B卷)》。
刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。
给定a-z,26个英文字母小写字符串组成的字符串A和B,其中A可能存在重复字母,B不会存在重复字母,现从字符串A中按规则挑选一些字母可以组成字符串B挑选规则如下:
求最多可以同时从A中挑选多少组能组成B的字符串。
输入为2行, 第一行输入字符串a,第二行输入字符串b,行首行尾没有多余空格。
输出一行,包含一个数字表示最多可以同时从a中挑选多少组能组成b的字符串,行末没有多余空格
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在线答疑。