代码随想录二刷第八天 | 28. 实现 strStr()、459.重复的子字符串

28. 实现 strStr()

题目:28. 找出字符串中第一个匹配项的下标 - 力扣(LeetCode)

题解:代码随想录

状态:需要多复习,多看

思路

KMP算法,实现方式为next数组初始化为0,不减一

代码

时间复杂度:O(m + n) 空间复杂度:O(m)

java 复制代码
class Solution {
    public int strStr(String haystack, String needle) {
        if(needle.length() == 0) return 0;
        if(needle.length() > haystack.length()) return -1;

        int[] next = new int[needle.length()];
        getNext(next, needle);

        int j = 0;
        for(int i = 0; i < haystack.length(); i++){
            while(j > 0 && haystack.charAt(i) != needle.charAt(j)){
                j = next[j - 1];
            }
            if(haystack.charAt(i) == needle.charAt(j)){
                j++;
            }
            if(j == needle.length()){
                return i - j + 1;
            }
        }

        return -1;
    }

    private static void getNext(int[] next, String s){
        int j = 0;
        next[0] = 0;
        for(int i = 1; i < s.length(); i++){
            while(j > 0 && s.charAt(i) != s.charAt(j)){
                j = next[j - 1];
            }
            if(s.charAt(i) == s.charAt(j)){
                j++;
            }
            next[i] = j;
        }
    }
}

459.重复的子字符串

题目:459. 重复的子字符串 - 力扣(LeetCode)

题解:代码随想录

状态:需要结合KMP多看

思路

KMP算法+移动匹配。abcabc+abcabc,去掉开头和结尾,在其中找abcabc

代码

时间复杂度:O(m + n) 空间复杂度:O(m)

java 复制代码
class Solution {
    public boolean repeatedSubstringPattern(String s) {
        return kmp(s+s, s);
    }

    private boolean kmp(String str, String pattern){
        int[] next = new int[pattern.length()];
        next[0] = 0;
        int j = 0;
        for(int i = 1; i < pattern.length(); i++){
            while(j > 0 && pattern.charAt(i) != pattern.charAt(j)){
                j = next[j - 1];
            }
            if(pattern.charAt(i) == pattern.charAt(j)){
                j++;
            }
            next[i] = j;
        }

        j = 0;
        for(int i = 1; i < str.length() - 1; i++){
            while(j > 0 && str.charAt(i) != pattern.charAt(j)){
                j = next[j - 1];
            }
            if(str.charAt(i) == pattern.charAt(j)){
                j++;
            }
            if(j == pattern.length()){
                return true;
            }
        }

        return false;
    }
}
相关推荐
unclecss12 分钟前
把 Spring Boot 的启动时间从 3 秒打到 30 毫秒,内存砍掉 80%,让 Java 在 Serverless 时代横着走
java·jvm·spring boot·serverless·graalvm
tuokuac17 分钟前
@PathVariable与@RequestParam
java·spring
q***160824 分钟前
Tomcat的server.xml配置详解
xml·java·tomcat
程序员西西24 分钟前
SpringBoot整合Apache Spark实现一个简单的数据分析功能
java·后端
n***840725 分钟前
Tomcat 乱码问题彻底解决
java·tomcat
LiLiYuan.28 分钟前
【Lombok库常用注解】
java·开发语言·python
培风图南以星河揽胜1 小时前
Java实习模拟面试|离散数学|概率论|金融英语|数据库实战|职业规划|期末冲刺|今日本科计科要闻速递:技术分享与学习指南
java·面试·概率论
能鈺CMS1 小时前
能鈺CMS · 虚拟发货源码
java·大数据·数据库
sheji34161 小时前
【开题答辩全过程】以 环保监督管理系统为例,包含答辩的问题和答案
java·eclipse
不会玩电脑的Xin.1 小时前
Web请求乱码解决方案
java·javaweb