Python:Рецепты/Поиск N максимальных и минимальных элементов: различия между версиями

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Нет описания правки
Нет описания правки
 
Строка 97: Строка 97:


=См.также=
=См.также=
{{ads}}


=Внешние ссылки=
=Внешние ссылки=


<references />
<references />
{{Навигационная таблица/Python}}
 
{{Навигационная таблица/Телепорт}}
{{Навигационная таблица/Портал/Python}}
{{SEO
|Заголовок статьи=Python:Рецепты - Поиск N максимальных и минимальных элементов / Онлайн справочник - wikihandbk.com
|Ключевые слова=python, рецепты python, Поиск N максимальных и минимальных элементов
|Описание статьи=
|Изображение статьи для Open Graph=
|Адрес страницы для schemaNewsArticle=<nowiki>http://wikihandbk.com/wiki/Python:Рецепты/Поиск N максимальных и минимальных элементов</nowiki>
|Изображение статьи для schemaNewsArticle=<nowiki></nowiki>
|Высота изображения статьи для schemaNewsArticle=
|Ширина изображения статьи для schemaNewsArticle=
|Дата публикации для schemaNewsArticle=2020-04-30
|Автор=Мякишев Е.А.
|Издатель=myagkij
|Логотип издателя для schemaNewsArticle=<nowiki>http://wikihandbk.com/ruwiki/images/6/61/Tech_geek_logo_1x.jpg</nowiki>
|Ширина логотипа издателя для schemaNewsArticle=60
|Высота логотипа издателя для schemaNewsArticle=45
}}


[[Категория:Рецепты]]
[[Категория:Рецепты]]

Текущая версия от 22:16, 12 марта 2023

Проверка/Оформление/Редактирование: Мякишев Е.А.


Поиск N максимальных и минимальных элементов

Задача

У вас есть коллекция элементов и вы хотите создать список из N максимальных или минимальных элементов.

Решение

Для этого подойдёт модуль heapq, в котором есть две функции nlargest() и nsmallest().

Пример

№1

Дана последовательность чисел:

nums = [111, -4, 0, 10, 56, -38, 11, 78, -9, 100, 99, 1,2,3]

Импортируем модуль:

import heapq

Получим 3 максимальных числа из последовательности:

print(heapq.nlargest(3, nums))

Результат:

[111, 100, 99]

Получим 3 минимальных числа из последовательности:

print(heapq.nsmallest(3, nums))

Результат:

[-38, -9, -4]

№2

Разберем пример с более сложной структурой данных, дан список отображений:

crypto= [
	{'name':'bitcoin','price': 7500, 'amount':50},
	{'name':'litecoin','price': 75, 'amount':75},
	{'name':'ethereum','price': 750, 'amount':115},
	{'name':'dogecoin','price': 0.075, 'amount':20000},
	{'name':'tron','price': 0.75, 'amount':1750},
	{'name':'monero','price': 65.75, 'amount':100}]

Импортируем модуль:

import heapq

Получим 3 отображения с максимальной ценой:

print(heapq.nlargest(3, crypto, key=lambda s: s['price']))

Результат:

[{'name': 'bitcoin', 'price': 7500, 'amount': 50}, {'name': 'ethereum', 'price': 750, 'amount': 115}, {'name': 'litecoin', 'price': 75, 'amount': 75}]

Получим 3 отображения с минимальным количеством монет:

print(heapq.nsmallest(3, crypto, key=lambda s: s['amount']))

Результат:

[{'name': 'bitcoin', 'price': 7500, 'amount': 50}, {'name': 'litecoin', 'price': 75, 'amount': 75}, {'name': 'monero', 'price': 65.75, 'amount': 100}]

См.также

Внешние ссылки