相关疑难解决方法(0)

如何判断字符串是否在Python中重复?

我正在寻找一种方法来测试一个给定的字符串是否为整个字符串重复自己.

例子:

[
    '0045662100456621004566210045662100456621',             # '00456621'
    '0072992700729927007299270072992700729927',             # '00729927'
    '001443001443001443001443001443001443001443',           # '001443'
    '037037037037037037037037037037037037037037037',        # '037'
    '047619047619047619047619047619047619047619',           # '047619'
    '002457002457002457002457002457002457002457',           # '002457'
    '001221001221001221001221001221001221001221',           # '001221'
    '001230012300123001230012300123001230012300123',        # '00123'
    '0013947001394700139470013947001394700139470013947',    # '0013947'
    '001001001001001001001001001001001001001001001001001',  # '001'
    '001406469760900140646976090014064697609',              # '0014064697609'
]
Run Code Online (Sandbox Code Playgroud)

是重复自己的字符串,和

[
    '004608294930875576036866359447',
    '00469483568075117370892018779342723',
    '004739336492890995260663507109',
    '001508295625942684766214177978883861236802413273',
    '007518796992481203',
    '0071942446043165467625899280575539568345323741',
    '0434782608695652173913',
    '0344827586206896551724137931',
    '002481389578163771712158808933',
    '002932551319648093841642228739',
    '0035587188612099644128113879',
    '003484320557491289198606271777',
    '00115074798619102416570771',
]
Run Code Online (Sandbox Code Playgroud)

是那些没有的例子.

我给出的字符串的重复部分可能很长,并且字符串本身可以是500或更多字符,因此循环遍历每个字符尝试构建模式然后检查模式与字符串的其余部分似乎非常慢.乘以可能数百个字符串,我看不到任何直观的解决方案.

我已经看了一下正则表达式,当你知道你在寻找什么,或者至少是你正在寻找的模式的长度时,它们看起来很好.不幸的是,我也不知道.

如何判断一个字符串是否重复,如果是,那么最短的重复子序列是什么?

python string pattern-matching

350
推荐指数
10
解决办法
4万
查看次数

标签 统计

pattern-matching ×1

python ×1

string ×1