力扣刷题-字符串-(※)重复的子字符串

459.重复的子字符串

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

示例 1:

输入: "abab"

输出: True

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

示例 2:

输入: "aba"

输出: False

示例 3:

输入: "abcabcabcabc"

输出: True

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

思路

https://www.programmercarl.com/0459.重复的子字符串.html#思路

具体的思路可以看代码随想录,讲解的很清晰。(暴力法、移动匹配法、KMP法

暴力法

python 复制代码
# 解法一:暴力法
class Solution(object):
    def repeatedSubstringPattern(self, s):
        """
        :type s: str
        :rtype: bool
        """
        n = len(s)
        if n <= 1:
            return False # 因为题目说的是由一个子串重复多次构成
        substr = ""
        for i in range(1, n//2+1): # 因为重复子串构成的前后半部分肯定一样
            if n % i == 0:
                substr = s[:i]
                if substr * (n//i) == s:
                    return True
        return False

KMP法

python 复制代码
# 解法二:KMP法
class Solution(object):
    def repeatedSubstringPattern(self, s):
        """
        :type s: str
        :rtype: bool
        """
        if len(s) == 0:
            return False
        next = [0]*len(s) # 对next数组初始化
        self.getNext(next, s)
        # 需要判断 next数组最后一个元素是否是-1
        if next[len(s)-1] != -1 and len(s) % (len(s) - (next[len(s)-1]+1)) == 0:
            return True
        return False
    
    def getNext(self, next, s):
        # 求next数组
        j = -1
        next[0] = -1
        for i in range(1, len(s)):
            while j >=0 and s[i] != s[j+1]:
                j = next[j]
            if s[i] == s[j+1]:
                j += 1
            next[i] = j
相关推荐
番茄灭世神5 分钟前
Python从入门到精通 第一章
python
B站_计算机毕业设计之家9 分钟前
豆瓣电影推荐系统 | Python Django Echarts构建个性化影视推荐平台 大数据 毕业设计源码 (建议收藏)✅
大数据·python·机器学习·django·毕业设计·echarts·推荐算法
风暴之零10 分钟前
变点检测算法PELT
算法
深鱼~10 分钟前
视觉算法性能翻倍:ops-cv经典算子的昇腾适配指南
算法·cann
李斯啦果11 分钟前
【PTA】L1-019 谁先倒
数据结构·算法
小镇敲码人15 分钟前
探索华为CANN框架中的ACL仓库
c++·python·华为·acl·cann
KIKIiiiiiiii15 分钟前
微信个人号API二次开发中的解决经验
java·人工智能·python·微信
梵刹古音16 分钟前
【C语言】 指针基础与定义
c语言·开发语言·算法
ZH154558913117 分钟前
Flutter for OpenHarmony Python学习助手实战:Web开发框架应用的实现
python·学习·flutter
Ekehlaft19 分钟前
这款国产 AI,让 Python 小白也能玩转编程
开发语言·人工智能·python·ai·aipy