问题描述
给定两个字符串 a 和 b,寻找重复叠加字符串 a 的最小次数,使得字符串 b 成为叠加后的字符串 a 的子串,如果不存在则返回 -1。
注意:字符串 "abc" 重复叠加 0 次是 "",重复叠加 1 次是 "abc",重复叠加 2 次是 "abcabc"。
示例 1:
输入:a = "abcd", b = "cdabcdab"
输出:3
解释:a 重复叠加三遍后为 "abcdabcdabcd", 此时 b 是其子串。
示例 2:输入:a = "a", b = "aa"
输出:2
示例 3:输入:a = "a", b = "a"
输出:1
示例 4:输入:a = "abc", b = "wxyz"
输出:-1来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/repeated-string-match
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Java
class Solution {
public int repeatedStringMatch(String a, String b) {
boolean[] visible = new boolean[26];
int aLen = a.length();
int bLen = b.length();
char[] as = a.toCharArray();
char[] bs = b.toCharArray();
//先遍历短的字符串
for(int i = 0;i < aLen;i++){
visible[as[i] - 'a'] = true;
}
for(int i = 0;i < bLen;i++){
if(!visible[bs[i] - 'a']){
return -1;
}
}
int repeat = bLen / aLen;
StringBuilder ss = new StringBuilder();
for(int i = 0;i < repeat;i++){
ss.append(a);
}
for(int i = 0;i <= 2;i++){
if(ss.indexOf(b) >= 0){
return repeat + i;
}
ss.append(a);
}
return -1;
}
}