zoukankan      html  css  js  c++  java
  • 重复的子字符串

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

    示例 1:

    输入: "abab"

    输出: True

    解释: 可由子字符串 "ab" 重复两次构成。
    示例 2:

    输入: "aba"

    输出: False
    示例 3:

    输入: "abcabcabcabc"

    输出: True

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

    public class RepeatedSubString {
        public boolean repeatedSubStringPattern(String s){
            String str =s + s ;
            return str.substring(1,2*s.length()-1).contains(s);
        }
    
        public boolean repeatedSubStringPattern2(String s){
            for (int i = 1; i < s.length(); i++){
                if(s.length() % i == 0){
                    String t = s.substring(0,i);
                    boolean flag = true;
                    for(int j= i; j+i <= s.length();j+=i) {
                        if (!t.equals(s.substring(j, j + i))) {
                            flag = false;
                            break;
                        }
                    }
                    if(flag){
                        return  true;
                    }
    
                }
            }
            return false;
        }
    
        public boolean repeatedSubStringPattern3(String s){
            for(int i=1; i<s.length(); i++){
                String str= rotate(s.toCharArray(),i);
                if(s.equals(str)){
                    return true;
                }
            }
            return false;
        }
        public String rotate(char[] nums, int k){
            k = k % nums.length;
            reverse(nums,0,nums.length-1);
            reverse(nums,0,k-1);
            reverse(nums,k,nums.length-1);
            return String.valueOf(nums);
        }
        public void reverse(char[] nums ,int begin, int end){
            int i= begin, j=end;
            while(i<j){
                char temp = nums[i];
                nums[i++] = nums[j];
                nums[j--] = temp;
            }
        }
        public static void main(String [] args){
            String s= "abcdabcdabcdabcd";
            RepeatedSubString b =new RepeatedSubString();
           boolean bb= b.repeatedSubStringPattern2(s);
            System.out.print(bb);
        }
    }
  • 相关阅读:
    Python Challenge 第五关
    Python Challenge 第四关
    Python Challenge 第三关
    Python Challenge 第二关
    Python Challenge 第一关
    使用Python计算研究生学分绩(绩点)
    CUDA程序计时
    Python远程视频监控程序
    grunt项目构建
    jQuery中.bind() .live() .delegate() .on()的区别
  • 原文地址:https://www.cnblogs.com/goodtest2018/p/13562786.html
Copyright © 2011-2022 走看看