问题一的原因是,当text以words开头时,i应该从0开始,而不是从1开始。所以应该将代码中的第13行和第19行的for循环改为`for i in range(len(text)+1):`。
问题二的原因是,当words包含多个单词时,你的代码在遍历每个单词时会重复执行相同的操作。你可以使用set来避免重复的项。同时,你没有给x.append()传递参数,所以它不能正常工作。下面是修正后的代码:text = input("请输入text的内容:")words = input("请输入words的内容:")x = []if words.isalnum(): for i in range(len(text)+1): for j in range(i+1, len(text)+1): if text.startswith(words, i, j): x.append(text[i:j]) breakelse: words = words.split() for each in set(words): for i in range(len(text)+1): for j in range(i+1, len(text)+1): if text.startswith(each, i, j): x.append(text[i:j]) breakprint(sorted(x))
这样,代码将输出所有匹配到的字符串,并按字母顺序进行排序。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。 |