Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 10.06.2021
Сообщений: 14

Реализация программы "Перевертыш"

01.07.2021, 20:00. Показов 1875. Ответов 2

Студворк — интернет-сервис помощи студентам
Доброго времени суток! Нужно реализовать программу "Перевертыш" с комментариями.

Задача:

"Пользователь вводит любое арифметическое выражение, используя целые числа и
знаки «+», «-», «*», «/». Необходимо вывести запись в обратной польской нотации".

На просторах интернета я нашел код, но не уверен в его правильности, да и комментарий нет.

Код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#перевертыш
 
ops = {'+':2, '-':2, '/':1, '*':1, '^':0}
 
INPUT = '3 + 4 * 2 / (11 - 5)^2'
 
stack, OUTPUT, digit = [], [], False
 
for s in INPUT:
    
    if s in '0123456789':
        if len(OUTPUT) == 0:
            OUTPUT = [s] + OUTPUT
        else:
            if OUTPUT[0][-1] in '0123456789' and digit: OUTPUT[0] += s
            else: OUTPUT = [s] + OUTPUT
        digit = True
    else: digit = False
    
    if s == '(':
        stack = [s] + stack
    
    if s == ')':
        while stack != [] and stack[0] != '(': OUTPUT, stack = [stack[0]] + OUTPUT, stack[1:]
        if stack != [] and stack[0] == '(': stack = stack[1:]
    if s in ops:
        while stack != [] and stack[0] in ops and ops[s] >= ops[stack[0]]: OUTPUT, stack = [stack[0]] + OUTPUT, stack[1:]
        stack = [s] + stack
 
while stack != []: OUTPUT, stack = [stack[0]] + OUTPUT, stack[1:]
 
print('инфиксная запись:\t%s' % (INPUT))
print('постфиксная запись:\t%s' % (" ".join(reversed(OUTPUT))))
Благодарю заранее за помощь!
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.07.2021, 20:00
Ответы с готовыми решениями:

Реализация программы
#include <iostream> #include <algorithm> #include <numeric> int main() { using namespace std; ...

Реализация программы
Всем привет, имеется NAS сервер с установленным transmission и его gui клиент на компьютере, требуется написать программу, которая при...

Реализация программы
Помогите сделать реализацию методов как должно выглядеть программа, т.е объявление и прочее, я весь запутался. Т.е 3 юнита и как...

2
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,733
Записей в блоге: 14
02.07.2021, 22:03
ubiiza12356, программа, похоже, правильная. Но ты все равно не сдашь... Даже если тебе написать комментарии.
1
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
04.07.2021, 12:48
Лучший ответ Сообщение было отмечено ubiiza12356 как решение

Решение

Ниасилил:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
def tokenizer(line):
    buf = []
    for i in line:
        if i in '0123456789':
            buf.append(i)
        elif i in '+-*/':
            if buf:
                yield ''.join(buf)
                buf.clear()
            yield i
        elif i in ' ':
            if buf:
                yield ''.join(buf)
                buf.clear()
        else:
            raise ValueError(i)
    if buf:
        yield ''.join(buf)
        buf.clear()
 
s = '3 + 4*2 / 11 - 5'
 
result = []
stack_op = []
for i in tokenizer(s):
    if i.isdigit():
        result.append(i)
    elif i in '+-*/':
        stack_op.append(i)
    print(i)
 
print(result)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.07.2021, 12:48
Помогаю со студенческими работами здесь

Реализация программы
Не могли бы Вы помочь написать программу, а то не до конца понимаю как её реализовать. Нужно написать на делфи interface type ...

Реализация в Паскале программы на С++
#include<istream> #include<iostream> using namespace std; void main() { setlocale(LC_ALL, "Russian"); char osmass; int...

Реализация программы по тестированию.
Требуют написать обучающую программу с тестом (те баллы - на сколько хорошо ученик освоил материал ) по теме теория вероятности (школьный...

Реализация программы тестирования
Здравствуйте. Обращаюсь к вам за помощью. У меня контрольная работа, с которой мне не удается справиться. Мне необходимо написать программу...

Реализация программы в excel
Необходимо создать цикл Repeat until в excel, прикрепленный к определенным ячейкам, через макрос. Помогите написать программный код.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru