zoukankan      html  css  js  c++  java
  • LeetCode 459. 重复的子字符串(Repeated Substring Pattern)

    459. 重复的子字符串
    459. Repeated Substring Pattern

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

    LeetCode459. Repeated Substring Pattern

    示例 1:

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

    示例 2:

    输入: "aba" 输出: False

    示例 3:

    输入: "abcabcabcabc" 输出: True 解释: 可由子字符串 "abc" 重复四次构成。(或者子字符串 "abcabc" 重复两次构成。)

    Java 实现

    class Solution {
        public boolean repeatedSubstringPattern1(String s) {
            int n = s.length();
            for (int i = n / 2; i > 0; i--) {
                if (n % i == 0) {
                    boolean flag = true;
                    for (int j = n / i; j > 1; j--) {
                        if (!s.substring(0, i).equals(s.substring(i * (j - 1), i * j))) {
                            flag = false;
                            break;
                        }
                    }
                    if (flag) {
                        return true;
                    }
                }
            }
            return false;
        }
    
        public boolean repeatedSubstringPattern2(String s) {
            String str = s + s;
            return str.substring(1, str.length() - 1).contains(s);
        }
    }
    

    相似题目

    参考资料

  • 相关阅读:
    百斯特
    C++
    转载
    转载+整理
    转载
    转载
    转载
    C++
    转载
    CodeForces
  • 原文地址:https://www.cnblogs.com/hgnulb/p/10923510.html
Copyright © 2011-2022 走看看