Назад к вопросам
Junior
10
Дана строка order задающая желаемый порядок на символах. Требуется в строке unsorted_str переставить символы так, чтобы порядок был согласован со строкой order. Обе строки состоят из символов английского алфавита в нижнем регистре, все символы в строке order различны. Порядок символов в строке unsorted_str называется согласованным со строкой order, если из того, что символ x стоит раньше символа y в order следует, что любое вхождение x в строке unsorted_str должно быть раньше любого вхождения y. Допустимы ситуации, когда в order нет символов из unsorted_str и наоборот. Верните любую из допустимых перестановок. unsorted_str = "abcd" order = "cba" answer = "dcba" ("cdba", "cbda", "cbad") def CustomSort(unsorted_str: str, order: str) -> str: # code here
Компании, где спрашивали
Яндекс
Ответ от нейросети
sobes.tech AI
Задача — отсортировать строку unsorted_str так, чтобы порядок символов соответствовал порядку, заданному в строке order.
Идея решения:
- Создать словарь с приоритетами символов из
order. - Для символов, которых нет в
order, можно задать приоритет, например, очень большой, чтобы они шли в конце. - Отсортировать символы
unsorted_strпо приоритету.
Пример реализации:
def CustomSort(unsorted_str: str, order: str) -> str:
priority = {char: i for i, char in enumerate(order)}
max_priority = len(order)
# Функция для получения приоритета символа
def get_priority(c):
return priority.get(c, max_priority)
# Сортируем символы по приоритету
sorted_chars = sorted(unsorted_str, key=get_priority)
return ''.join(sorted_chars)
# Пример
unsorted_str = "abcd"
order = "cba"
print(CustomSort(unsorted_str, order)) # Вывод: dcba или другой допустимый вариант
Таким образом, символы из order будут расположены в нужном порядке, а остальные — после них.