gpt4 book ai didi

python - 有没有一种简单的方法来获得包含某个字母的最长单词?

转载 作者:太空宇宙 更新时间:2023-11-04 11:21:25 25 4
gpt4 key购买 nike

我试图通过 for 循环获取包含字母“f”的最大单词,通过我的代码,我试图使用 if 和 and 语句使其尽可能简单。但是它不起作用,因为它返回最大的单词而不是包含字母 f 的单词,为什么它不起作用?

def main():
sentence = "Absence makes the heart grow fonder"
letter = "f"
longest_word = get_longest_word(sentence, letter)
print('"' + longest_word + '" is the longest word containing the letter "'
+ letter + '".')

def get_longest_word(sentence, letter):
words_list = sentence.split()
largest = words_list[0]
my_list = []
for word in words_list:
if letter in word and len(word) > len(largest):
largest = word
return largest


main()

最佳答案

原因是你初始化largestwords_list[0],也就是'Absence'最长的单词句子

因此,即使达到了 'fonder',即使您的 if 的第一部分通过了(它包含一个 'f' ),关于长度的第二部分没有。

就我个人而言,我会这样做:

from operator import itemgetter

def get_longest_word(sentence, letter):
words_with_letter = ((word, len(word)) for word in sentence.split() if letter in word)
return max(words_with_letter, key=itemgetter(1))[0]

这会将句子转换成一个可迭代的元组,其中第一个元素是单词,第二个元素是它的长度,并且所有单词都已经包含有问题的字母 .

然后,我们需要做的就是获取长度最长的单词,即第二个位置的最高值。

输出:

"fonder" is the longest word containing the letter "f".

关于python - 有没有一种简单的方法来获得包含某个字母的最长单词?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55912130/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com