|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
问题:编写一个程序,判断输入的字符串是否由多个子字符串重复多次构成。
举例:
输入:"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[i:i*2]) and s.count(s[i:i*2]) == n/i: #: 请解释一下这行代码,s.startswith(s[i:i*2])的意义是什么?把这一行换成 if s.count([s[i:i*2]]) == 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[0] 开始,到 s[i - 1] 结束,长度为 i
- print('True')
- break
- else:
- print('False')
复制代码
|
|