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

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

01.07.2021, 20:00. Показов 1855. Ответов 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
38171 / 21106 / 4307
Регистрация: 12.02.2012
Сообщений: 34,699
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru