栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

LeetCode 686.重复叠加字符串匹配 每日一题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode 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
示例 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;
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/888583.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号