美文网首页
重复叠加字符串匹配

重复叠加字符串匹配

作者: xialu | 来源:发表于2021-12-22 22:19 被阅读0次

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/repeated-string-match

    题目描述:

    给定两个字符串 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

    思路:
    1. 先判断b是否a的子串,是则直接返回.
    2. a叠加一次,再判断b是否是a的子串,直到a串的长度超过b串加a串为止,还没找到则不存在,返回-1
    代码实现:
    class Solution {
        public int repeatedStringMatch(String a, String b) {
            int a_len = a.length();
            int b_len = b.length();
            int idx = 1;  
            String c = a;
            int c_len = a_len;
            if (c.contains(b)) return idx;
            do {
                idx++;
                c_len += a_len;
                c += a;
                if (c.contains(b)) return idx;
            } while(c_len <= (b_len + a_len));
            return -1;
        }
    }
    

    相关文章

      网友评论

          本文标题:重复叠加字符串匹配

          本文链接:https://www.haomeiwen.com/subject/fhycqrtx.html