作业字符串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,请各位大佬指点 这段代码存在一些问题。首先,在判断字符串是否可由重复子串构成时,我们应该从长度为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 小助理,如未能正确解答您的问题,请继续追问。 {:10_249:} shenceny 发表于 2024-5-31 19:05
{:10_290:}
页:
[1]