Сортировка списка по индексам
Напишите функцию sort_by_indexes(lst, indexes, reverse=False)
, которая принимает два списка в качестве аргументов и возвращает новый список, отсортированный на основе индексов второго списка. Функция должна иметь следующие параметры:
lst
: Список элементов, которые нужно отсортировать.
indexes
: Список целых чисел, представляющих желаемые индексы для сортировки списка lst
.
reverse
: Необязательный логический параметр, который, когда установлен в True
, сортирует список в обратном порядке.
Функция должна возвращать новый список, отсортированный на основе индексов второго списка.
def sort_by_indexes(lst, indexes, reverse=False):
return [val for (_, val) in sorted(zip(indexes, lst), key=lambda x: \
x[0], reverse=reverse)]
a = ['eggs', 'bread', 'oranges', 'jam', 'apples','milk']
b = [3, 2, 6, 4, 1, 5]
sort_by_indexes(a, b) ## ['apples', 'bread', 'eggs', 'jam','milk', 'oranges']
sort_by_indexes(a, b, True)
## ['oranges','milk', 'jam', 'eggs', 'bread', 'apples']