给定两个字符串 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
思路:根据字符串a和b的长度,计算拼接字符串的最小拼接次数,使得拼接后的字符串不小于字符串b的长度。如果拼接后的字符串不包含字符串b,则再拼接一次a,看拼接后的是否包含字符串b。
解法二:
使用KMP算法 ,先计算b的前缀函数,在做文本匹配时,如果文本的下标与模式的下标之差大于a的长度,说明不存在。
具体代码参考:
https://github.com/wuli2496/OJ/tree/master/LeetCode/686%20Repeated%20String%20Match