Создание словаря на основе приоритета оператора в python

#python #stack #operators

#python #стек #операторы

Вопрос:

Я новичок в Python, и в последнее время я изучал структуры данных на Python, а именно списки, кортежи, словари и все такое прочее. Теперь, в качестве небольшого учебного упражнения, я хотел бы написать преобразователь инфикса в постфикс, используя алгоритм Shunting Yard. Итак, я уже писал эту программу раньше на C, и там, чтобы получить приоритет оператора, я определил только функцию, которая возвращает приоритет токена, используя оператор switch . Здесь я в недоумении, потому что операторов switch не существует. Уродливым решением было бы сделать то же самое, но с операторами elif, это мое последнее средство, но есть ли более элегантное решение с использованием словарей?

На данный момент мой словарь выглядит так:

priorities = {1: (' ', '-'), 2: ('*', '/'), 3: '^'}

Как вы можете видеть, несколько операторов имеют одинаковый приоритет, мой вопрос в том, как я могу узнать приоритет любого данного токена, используя эту структуру? Если мой токен ‘^’, это просто, просто приоритеты [‘^’], но если это любой другой оператор? Как я могу связать их с кортежем, который их содержит? что-то вроде приоритетов [‘ ‘]?

Ответ №1:

Почему бы не инвертировать словарь?

 {'^': 3, '*': 2, '/': 2, ' ':1, '-':1}