62.重复的子字符串-LeetCode-Java-待完善

给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。

示例 1:
输入: "abab" 输出: True
解释: 可由子字符串 "ab" 重复两次构成。

示例 2:
输入: "aba" 输出: False

示例 3:
输入: "abcabcabcabc" 输出: True
解释: 可由子字符串 "abc" 重复四次构成。 (或者子字符串 "abcabc" 重复两次构成。)
/**
 * 解法一:比如字符串"abcabcabcabc"
 * 从头做异或运算,访问到abcabc结果=0,截取一半'abc'作为可能的子字符串,然后整体check()看是否满足。
 */
class Solution {
    public boolean repeatedSubstringPattern(String s) {
        int x = 0;
        for (int i = 0; i < s.length(); i++) {
            x ^= s.charAt(i);
            if (x == 0) {
                System.out.println(i);
                if (check((i + 1) / 2, s)) return true;
            }
        }
        return false;
    }

    private boolean check(int k, String s) {
        int len = k;
        String subStr = s.substring(0, len);
        while (k + len <= s.length()) {
            if (s.substring(k, k + len).equals(subStr)) k += len;
            else break;
        }
        if (k == s.length()) return true;
        else return false;
    }
}

/**
 * 解法二:如果s是由子字符串组成的,那么s循环移动 子字符串长度 后不变。
 * 子字符串长度范围 1<=len<=s.lenght()-1
 * 如:s="abab" s+s ="abababab"
 * s循环移动1位刚好是 s+s中的a(baba)bab,移动2位是ab(abab)ab,所以s+s包含所有s循环移动的结果
 */
class Solution {
    public boolean repeatedSubstringPattern(String s) {
        String str = s + s;
        return str.substring(1, str.length() - 1).contains(s);
    }
}

/**
 * 待完善 KMP算法
 */

©️2020 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值