Sobes.tech
Назад к вопросам
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.

Идея решения:

  1. Создать словарь с приоритетами символов из order.
  2. Для символов, которых нет в order, можно задать приоритет, например, очень большой, чтобы они шли в конце.
  3. Отсортировать символы 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 будут расположены в нужном порядке, а остальные — после них.