求大佬解释一下这行代码
问题:编写一个程序,判断输入的字符串是否由多个子字符串重复多次构成。举例:
输入:"FCFC"
输出:True
输入:"FishCFish"
输出:False
输入:"FCCF"
输出:False
输入:"FishCFishc"
输出:False
小甲鱼答案:
s = input("请输入一个由字母构成的字符串:")
n = len(s)
for i in range(1, n//2+1):
# 如果子字符串的长度为i,则n必须可以被i整除才行
if n % i == 0:
# 如果子字符串的长度为i,则i到i*2之间是一个重复的子字符串
if s.startswith(s) and s.count(s) == n/i: #: 请解释一下这行代码,s.startswith(s)的意义是什么?把这一行换成 ifs.count(])==n/i 的话不也能实现目标吗?
print(True)
break
# for...else的用法,小甲鱼希望大家还没有忘记哦^o^
else:
print(False) 本帖最后由 jackz007 于 2022-10-7 17:27 编辑
小甲鱼把简单问题复杂化了,这个代码如果改成这样是不是好理解多了?
s = input("请输入一个由字母构成的字符串:")
for i in range(2 , len(s) // 2 + 1): # 枚举子字符串的长度从 2 到 len(s) // 2
if len(s) % i == 0:
if s . count(s[: i]) == len(s) // i : # 子字符串的提取从 s 开始,到 s 结束,长度为 i
print('True')
break
else:
print('False')
页:
[1]