鱼C论坛

 找回密码
 立即注册
查看: 3482|回复: 1

[已解决]求大佬解释一下这行代码

[复制链接]
发表于 2022-10-7 16:27:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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)
最佳答案
2022-10-7 17:20:16
本帖最后由 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')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-10-7 17:20:16 | 显示全部楼层    本楼为最佳答案   
本帖最后由 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')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-25 22:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表