Найдите две самые длинные строки из списка || или второй самый длинный список в PYTHON - PullRequest
0 голосов
/ 27 марта 2012

Я хотел бы знать, как я могу найти две самые длинные строки из списка (массива) строк или как найти вторую самую длинную строку из списка. спасибо

Ответы [ 4 ]

5 голосов
/ 27 марта 2012

Самый простой способ сделать это - использовать функцию sorted(), используя другую встроенную функцию len в качестве аргумента key следующим образом:

>>> foo = ['dddd', 'ccc', 'bb', 'a', 'eeeee']
>>> sorted(foo, key=len)[-2]
'dddd'

или если вам нужны два самых длинных:

>>> sorted(foo, key=len)[-2:]
['dddd', 'eeeee']
5 голосов
/ 27 марта 2012

Вы можете сделать это, используя стандартный модуль heapq :

>>> lst = ['hello', 'blah', 'boo', 'braininess']
>>> heapq.nlargest(2, lst, key=len)
['braininess', 'hello']
1 голос
/ 27 марта 2012

Если a - ваш список строк, то a.sort (key = len) отсортирует ваш список строк по их длине.Самым длинным будет [-1], а вторым самым длинным будет [-2].`

0 голосов
/ 27 марта 2012
l = ['123', '12345', '12']
l.sort(key=lambda item: len(item))
l.[-1] # longest
l.[-2] # second longest
...