python⾯试题⼀个字符串是否由重复的⼦字符串组成
⼀,给定⼀个⾮空的字符串,判断它是否可以由它的⼀个⼦串重复多次构成。给定的字符串只含有⼩写英⽂字母,并且长度不超过10000。
输⼊: "abab"
输出: True
解释: 可由⼦字符串"ab"重复两次构成。
输⼊: "aba"
输出: False
字符串长度0到59输⼊: "abcabcabcabc"
输出: True
解释: 可由⼦字符串"abc"重复四次构成。 (或者⼦字符串"abcabc"重复两次构成。)
⼆、代码和思路
1.这⾥ if n%i==0这句判断函数的作⽤是判断i是否的n的约数,如果是就将s分为n/i个窗⼝逐个⽐较,没符合⼀次向后滑动⼀次,最后查看窗⼝的位置,如果已经滑到了s的最后,那么则符合题意,返回true
2.逐个判断完所有的0-n//2的数后如果仍然没到符合条件的数那么返回false
class Solution(object):
def repeatedSubstringPattern(self, s):
"""
:type s: str
:rtype: bool
"""
n=len(s)
for i in range(1,n//2+1):
if n%i==0:
a=s[:i];j=i
while j<n and s[j:j+i]==a:
j += i
if j==n:return True
return False
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论