Почему результат сортировки списков Python так странно? [дублировать]Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Почему результат сортировки списков Python так странно? [дублировать]

Сообщение Anonymous »

Код выглядит следующим образом, используя функцию ключа для подсчета количества раз, когда каждый элемент появляется в списке:

Код: Выделить всё

input_list = list('aaddccdc')
input_list.sort(key=lambda i: (-input_list.count(i), ord(i)))
print(input_list)
< /code>
Мы получаем результат в неожиданном порядке < /p>
['a', 'a', 'c', 'c', 'c', 'd', 'd', 'd']
Если он изменен, чтобы мы использовали копию в ключе function

Код: Выделить всё

input_list = list('aaddccdc')

snapshot = input_list.copy()
input_list.sort(key=lambda i: (-snapshot.count(i), ord(i)))

print(input_list)
< /code>
Мы получаем различный, ожидаемый заказ < /p>
['c', 'c', 'c', 'd', 'd', 'd', 'a', 'a']
Почему это?>

Подробнее здесь: https://stackoverflow.com/questions/796 ... so-strange
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»