686. 重复叠加字符串匹配 中等

给定两个字符串 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
输入:a = "abc", b = "wxyz"
输出:-1

提示:

  • 1 <= a.length <= 104
  • 1 <= b.length <= 104
  • a 和 b 由小写英文字母组成

代码参考:

package main

import (
    "fmt"
    "strings"
)

func main() {
    fmt.Println(repeatedStringMatch("abcd", "abcdabcdabcd")) // 3
    fmt.Println(repeatedStringMatch("abc", "cabcabca"))      // 4
}

// b 最多要 a 重复 a+Na+a 次
func repeatedStringMatch(A string, B string) int {
    count := 1
    a := A
    maxCount := len(B)/len(A) + 2
    for count <= maxCount {
        if strings.Contains(A, B) {
            return count
        }
        A += a
        count++
    }
    return -1
}
最后编辑: kuteng  文档更新时间: 2021-06-05 10:16   作者:kuteng