zoukankan      html  css  js  c++  java
  • Leetcode: Repeated Substring Pattern

    Given a non-empty string check if it can be constructed by taking a substring of it and appending multiple copies of the substring together. You may assume the given string consists of lowercase English letters only and its length will not exceed 10000.
    
    Example 1:
    Input: "abab"
    
    Output: True
    
    Explanation: It's the substring "ab" twice.
    Example 2:
    Input: "aba"
    
    Output: False
    Example 3:
    Input: "abcabcabcabc"
    
    Output: True
    
    Explanation: It's the substring "abc" four times. (And the substring "abcabc" twice.)

    这道题应该没法用DP等解,只能brute force 或者 KMP(为深究)

    BruteForce, Best Solution for now except KMP

     1 public boolean repeatedSubstringPattern(String str) {
     2     int l = str.length();
     3     for(int i=l/2;i>=1;i--) {
     4         if(l%i==0) {
     5             int m = l/i;
     6             String subS = str.substring(0,i);
     7             StringBuilder sb = new StringBuilder();
     8             for(int j=0;j<m;j++) {
     9                 sb.append(subS);
    10             }
    11             if(sb.toString().equals(str)) return true;
    12         }
    13     }
    14     return false;
    15 }

    作为Encode String with Shortest Length的subproblem

     1 public class Solution {
     2     public boolean repeatedSubstringPattern(String str) {
     3         int len = str.length();
     4         for (int i=len/2; i>0; i--) {
     5             if (len%i == 0) {
     6                 String substr = str.substring(0, i);
     7                 if (str.replaceAll(substr, "").length() == 0) 
     8                     return true;
     9             }
    10         }
    11         return false;
    12     }
    13 }

    KMP解法未研究,https://discuss.leetcode.com/topic/67590/java-o-n

  • 相关阅读:
    STS和Eclipse安装Lombok插件
    html5盒子模型
    SpringBoot整合Ribbon注入RestTemplate实例找不到原因
    Tomcat调整JVM大小,启动闪退
    quick cocos 设置屏幕大小
    quick cocos 多点触控,真机测试成功
    quick cocos 打包apk
    cocos3 多点触控 经过真机测试
    corona image sheet
    corona 杂类
  • 原文地址:https://www.cnblogs.com/EdwardLiu/p/6168442.html
Copyright © 2011-2022 走看看