Java实现 LeetCode 466 统计重复个数

466. 统计重复个数

定义由 n 个连接的字符串 s 组成字符串 S,即 S = [s,n]。例如,[“abc”, 3]=“abcabcabc”。

另一方面,如果我们可以从 s2 中删除某些字符使其变为 s1,我们称字符串 s1 可以从字符串 s2 获得。例如,“abc” 可以根据我们的定义从 “abdbec” 获得,但不能从 “acbbe” 获得。

现在给出两个非空字符串 S1 和 S2(每个最多 100 个字符长)和两个整数 0 ≤ N1 ≤ 106 和 1 ≤ N2 ≤ 106。现在考虑字符串 S1 和 S2,其中S1=[s1,n1]和S2=[s2,n2]。找出可以使[S2,M]从 S1 获得的最大整数 M。

示例:

输入:
s1 =“acb”,n1 = 4
s2 =“ab”,n2 = 2

返回:
2

class Solution {
    public int getMaxRepetitions(String s1, int n1, String s2, int n2) {
        if(s1 == null || s2 == null) return 0;
        int n = s1.length(), m = s2.length();
        int index = 0, cnt = 0;
        int[] count = new int[m+2], nxt = new int[m+2];
        for(int i = 1; i <= m + 1 && i <= n1; ++i){
            for(int j = 0; j < n; ++j){
                if(s2.charAt(index) == s1.charAt(j)) index++;
                if(index >= m){
                    index = 0;
                    cnt++;
                }
            }
            count[i] = cnt;
            nxt[i] = index;
            for(int j = 1; j < i; ++j){
                if(nxt[j] == nxt[i]){
                    int repeat = count[i] - count[j];
                    int repeat_num = repeat * ((n1 - j) / (i - j));
                    int remain_num = count[j + (n1 - j) % (i - j)];
                    return (repeat_num + remain_num) / n2;
                }
            }
        }
        return count[n1] / n2;
    }
}
  • 22
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 27
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值