Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.93/180: Рейтинг темы: голосов - 180, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 24.06.2019
Сообщений: 7

Обратная польская запись

01.10.2019, 14:36. Показов 35958. Ответов 20

Студворк — интернет-сервис помощи студентам
программа не переводит выражение в обратную польскую запись
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
34
35
36
37
38
39
40
41
42
43
list = input("Введите выражение -  ")
a = list
t = ['+', '-', '*', '/']
stroka = []
stek = []
c = 0
for i in a:
    if i == t[0]:
       stek.append(i)
       c += 1
    elif i == t[1]:
       stek.append(i)
       c += 1
    elif i == t[2]:
       stek.append(i)
       c += 1
    elif i == t[3]:
       stek.append(i)
       c += 1
    else : stroka.append(i)
    while c > 1: 
        for v in stek[1:]:
            for i in stek:
                if v == t[0] and i == t[0] or i == t[1] or i == t[2] or i == t[3]:
                    stroka.append(v)
                    stek.remove(i)
                    c -= 1
                elif v == t[1] and i == t[0] or i == t[1] or i == t[2] or i == t[3]:
                    stroka.append(v)
                    stek.remove(i)
                    c -= 1
                elif v == t[2] and i == t[3] or i == t[2]:
                    stroka.append(v)
                    stek.remove(i)
                    c -= 1
                elif v == t[3] and i == t[2] or i == t[3]:
                    stroka.append(v)
                    stek.remove(i)
                    c -= 1
                else : c = 0
                
print(stroka)
print(stek)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.10.2019, 14:36
Ответы с готовыми решениями:

Обратная польская нотация
Такой тип записи арифметических выражений позволяет однозначно определять последовательность действий, не используя скобки. При такой...

Обратная польская запись
# Функция для проверки, является ли символ оператором def is_operator(c): return c in # Функция для определения приоритета...

Обратная польская запись (reversed polish notation)
Можете, пожалуйста написать в питоне код преобразования строки с числами и операциями в строку обратной польской записи? И, пожалуйста,...

20
712 / 351 / 120
Регистрация: 09.12.2020
Сообщений: 918
26.04.2022, 16:47
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от VistaSV30 Посмотреть сообщение
Имеет ли смысл, для ускорения вычислений использовать принцип ОПЗ применительно к выражениям в обычной (инфиксной) записи?
думаю, что существенного преимущества (что и показывают ваши тесты) это, конечно, не даст. По моему мнению обсуждать эту тему стоит не из за повышения эффективности при использовании ОПЗ, а из за того, каким интересным алгоритмом эта запись программируется. Позволяет понять что такое стеки(при вычислении), довольно сложный и интересный алгоритм для перевода инфиксной в постфиксную.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.04.2022, 16:47

Обратная польская запись
Подскажите, как по обратной польской записи выражения построить дерево выражения Например: дана запись 1 2 + 3 4...

Обратная польская запись
программа "Стековая машина", она работает только с бинарными операциями,нужно чтобы работала еще с унарными операциями(синус,косинус итд) ...

Обратная польская запись
Вот задача: ввести операцию обычной записью, она выводиться польской и выдает ответ . Как вводить постфикстно и считалось , как-то...

Обратная польская запись
Добрый день! Нужна ваша помощь. Процедура не правильно выводит обратную польскую запись. Что нужно изменить? public string...

Обратная польская запись
Подскажите, где могу прочитать темы: Представление данных в памяти компьютера. Прямой код, Стек и программы работы с ним, Очередь и...


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

Или воспользуйтесь поиском по форуму:
21
Ответ Создать тему
Новые блоги и статьи
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы ### Аннотация Представлено исследование по разработке агентной модели микоризной. . .
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru