|
0 / 1 / 0
Регистрация: 24.11.2020
Сообщений: 138
|
|||||||||||
Обратная польская нотация09.03.2022, 22:04. Показов 7625. Ответов 5
Метки нет (Все метки)
Такой тип записи арифметических выражений позволяет однозначно определять последовательность действий, не используя скобки. При такой записи (постфиксная форма) выражения вычисляются слева направо. Алгоритм такой.
Идем по строке, пока не встретим арифметический оператор. Берем два расположенных перед ним числа (операнда) и производим с ними действие, которое записано в этом операторе. Порядок операндов не меняем. Полученное число записываем в строку вместо этих трех элементов – двух операндов и арифметического оператора. Повторяем действия, пока в строке не останется только одно число – это и есть результат вычислений. Напишите класс RPN (Reverse Polish Notation) для составления и вычисления арифметического выражения, записанного в обратной польской нотации. Класс инициализируется с аргументом – строкой, в которой записано арифметическое выражение, которое может содержать числа, знаки арифметических операций (+-*/) и круглые скобки, составленное по правилам математики; все числа и знаки разделены пробелами. Если это выражение не преобразовано к обратной польской записи, то при вызове метода вычислений, нужно его сначала преобразовать, и только потом вычислять. Класс реализует методы: check() – проверяет переданную при инициализации строку; если она записана в постфиксной форме, то возвращает False, то есть преобразование не требуется; иначе возвращает True. postfix() – преобразует строку, переданную экземпляру класса при инициализации, к обратной польской записи; возвращает выражение в постфиксной форме. calculate() – вычисляет значение выражения, переданного экземпляру класса при инициализации; если выражение записано не в постфиксной форме, сначала его нужно к ней преобразовать; возвращает число – результат вычислений. Поскольку среди операций присутствует деление, на всякий случай всегда результат возвращаем в вещественном виде. Пример 1 Ввод Вывод
9 5 2 + - 3 * 1 7 + * 48.0 Пример 2 Ввод Вывод
16 7 2 - 8 * + 8 / 7.0
0
|
|||||||||||
| 09.03.2022, 22:04 | |
|
Ответы с готовыми решениями:
5
Обратная польская запись Обратная польская запись (reversed polish notation) |
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
||||||
| 13.03.2022, 10:28 | ||||||
0
|
||||||
|
0 / 1 / 0
Регистрация: 24.11.2020
Сообщений: 138
|
|
| 13.03.2022, 13:01 [ТС] | |
|
stdout:
/bin/sh ./build.sh 1>&2 Makefile:2: recipe for target 'build' failed stderr: ./solution.py:7:15: E999 SyntaxError: invalid syntax Код не соответствует стандарту PEP8 или в нем есть синтаксические ошибки make: *** [build] Error 1
0
|
|
|
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
|
||
| 13.03.2022, 14:07 | ||
|
В Python 3.10 введена новая конструкция match/case А у вас версия наверно ниже десятой?
0
|
||
|
0 / 1 / 0
Регистрация: 24.11.2020
Сообщений: 138
|
|
| 13.03.2022, 15:21 [ТС] | |
|
может быть компиллятор в системе LMS не поддерживает 10 версию
0
|
|
|
7 / 7 / 0
Регистрация: 29.01.2022
Сообщений: 55
|
||||||
| 22.02.2023, 22:41 | ||||||
1
|
||||||
| 22.02.2023, 22:41 | |
|
Помогаю со студенческими работами здесь
6
Обратная польская нотация Обратная Польская Нотация Обратная Польская Нотация Обратная польская нотация Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
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
Использованы. . .
|