蔡先生V 发表于 2024-5-31 12:03:40

作业字符串3中的第二个动手题

s = input("请输入一个由字母构成的字符串:")
   
n = len(s)
for i in range(1, n//2 + 1):
    if n % i == 0:
      if s.startswith(s[:i]) and s.count(s[:i]) == n/i:
            print(True)
            break

else:
    print(False)

这串代码实现不了题目所给结果,返回的都是False,请各位大佬指点

FishC 发表于 2024-5-31 12:03:51

这段代码存在一些问题。首先,在判断字符串是否可由重复子串构成时,我们应该从长度为1开始尝试,逐渐增加子串的长度,而不是从长度为n/2开始遍历。其次,在判断字符串是否可由某个子串重复拼接而成时,应该判断s是否能被该子串整除,而不是判断子串能否被s整除。

下面是修正后的代码示例:

s = input("请输入一个由字母构成的字符串:")

n = len(s)
for i in range(1, n//2 + 1):
    if n % i == 0:
      sub_str = s[:i]# 提取长度为i的子串
      temp_str = sub_str * (n // i)# 构造重复拼接的字符串
      if s == temp_str:
            print(True)
            break
else:
    print(False)

这样修改后的代码会根据子串的长度逐个尝试,如果找到一个能够将原字符串拼接出来的子串,则输出True;否则,执行完整个for循环后输出False。

希望对你有帮助!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

shenceny 发表于 2024-5-31 19:05:53

{:10_249:}

蔡先生V 发表于 2024-6-3 11:42:48

shenceny 发表于 2024-5-31 19:05


{:10_290:}
页: [1]
查看完整版本: 作业字符串3中的第二个动手题