代码随想录 -- 字符串 -- 重复的子字符串

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

暴力解法:

思路:

        假设子串 s' 长度 n' 为 i,从1到n/2遍历:

        1. 如果 s 能够由他的子串重复构成,那么 s 的长度 n 一定整除其子串 s' 的长度 n',

        2. 如果 s[:i] * n/n'==s,符合题意

class Solution(object):
    def repeatedSubstringPattern(self, s):
        n=len(s)
        for i in range(1,n/2+1):
            substr = s[:i]
            if n%len(substr)==0:
                if s[:i]*(n/len(substr))==s:
                    return True
        return False

题解的两种方法一种是移动匹配,一种是KMP

移动匹配

上面是充分性的证明,必要性的证明看不明白。。。

class Solution:
    def repeatedSubstringPattern(self, s: str) -> bool:
        n = len(s)
        if n <= 1:
            return False
        ss = s[1:] + s[:-1] 
        print(ss.find(s))              
        return ss.find(s) != -1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值