0 / 0 / 0
Регистрация: 07.04.2019
Сообщений: 69

Вычисление арифметического выражения, введённого в виде символьной строки

14.04.2019, 15:33. Показов 67064. Ответов 13

Студворк — интернет-сервис помощи студентам
Напишите программу, которая вычисляет арифметическое выражение, введённое в виде символьной строки. Выражение содержит только целые числа, знаки арифметических действий (сложения, вычитания, умножения и деления) и круглые скобки правильной вложенности.

Входные данные:
Входная строка содержит запись арифметического выражения.

Выходные данные:
Программа должна вывести результат вычисления переданного ей выражения.

Например:
входные данные:
(2+13)*4-28*(329/(23-17))
выходные данные:
-1452
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.04.2019, 15:33
Ответы с готовыми решениями:

Калькулятор: вычисление арифметического выражения, введённого в виде символьной строки
Привет,не понимаю в чём смысл задачи) Питон же сам считает) Напишите программу, которая вычисляет арифметическое выражение,...

Вычислить значение арифметического выражения, записанного в виде символьной строки
Напишите программу, которая вычисляет значение арифметического выражения, записанного в виде символьной строки. В выражении используются...

Вычисление арифметического выражения, введённого пользователем в строку
Cобственно, условие задачи: Пользователь вводит с клавиатуры арифметическое выражение. Например, 24+1.Необходимо вывести на экран...

13
Эксперт Pascal/Delphi
 Аватар для droider
4889 / 2823 / 865
Регистрация: 04.10.2012
Сообщений: 10,268
14.04.2019, 16:07
Цитата Сообщение от jxstixn Посмотреть сообщение
Никак не могу догадаться
Парсер математических выражений
0
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
14.04.2019, 17:07
С чего Вы взяли, что будет 1452?
Python
1
print(eval('(2+13)*4-28*(329/(23-17))'))
0
Эксперт Pascal/Delphi
 Аватар для droider
4889 / 2823 / 865
Регистрация: 04.10.2012
Сообщений: 10,268
14.04.2019, 17:15
jxstixn, чуть округлим и будет
Code
1
-1475,33
0
0 / 0 / 0
Регистрация: 07.04.2019
Сообщений: 69
14.04.2019, 21:14  [ТС]
Строка может быть любая, она вводится, а функция eval,насколько мне известно, действия в скобках не выполняет.

Добавлено через 15 секунд
m0nte-cr1st0, Строка может быть любая, она вводится, а функция eval,насколько мне известно, действия в скобках не выполняет.
0
Эксперт Pascal/Delphi
 Аватар для droider
4889 / 2823 / 865
Регистрация: 04.10.2012
Сообщений: 10,268
14.04.2019, 21:30
Цитата Сообщение от jxstixn Посмотреть сообщение
функция eval...действия в скобках не выполняет
выполняет.
Цитата Сообщение от jxstixn Посмотреть сообщение
Строка может быть любая, она вводится
так передавайте нужное выражение строкой. В чем проблема?
Python
1
2
expression = input('Что вычислить?')
print(eval(expression))
Пример

Code
1
2
3
Что вычислить? 1+(2+14)/(4-2)
9.0
>>>
0
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
14.04.2019, 22:05
Цитата Сообщение от jxstixn Посмотреть сообщение
а функция eval,насколько мне известно, действия в скобках не выполняет.
Вы бы проверяли, прежде чем бред писать...
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
15.04.2019, 01:21
Цитата Сообщение от jxstixn Посмотреть сообщение
Строка может быть любая, она вводится, а функция eval,насколько мне известно, действия в скобках не выполняет.
Функция eval выполняет любую строку, если эта строка соответствует строке кода в питоне.

пример:
Python
1
2
3
>>> x = 1
>>> eval('(x + 1)')
2
Добавлено через 8 минут
Синтаксис:

eval(expression, globals=None, locals=None) -> Результат выполненного выражения


expression : Выражение, которое требуется исполнить, в виде строки. Либо объект кода.

globals=None : Ожидается dict. Словарь глобального пространства, относительно которого следует исполнить выражение. Если указан, но не содержит атрибута __builtins__ данные указанного пространства будут дополнены данными общего глобального пространства, перед разбором выражения. Таким образом, выражение будет иметь доступ ко всем встроенным модулям.

locals=None : Ожидается объект-отображение (например, dict). Локальное пространство, в котором следует исполнить выражение. Если не указано, то используется словарь глобального пространства.
Если оба аргумента опущены, то выражение будет выполнено в среде, где был осуществлён вызов функции.
В случае ошибок возбуждает SyntaxError
0
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 12
16.07.2020, 12:56
а возможно эту задачу решить с помощью бинарного дерева??? Без функции eval!!
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
16.07.2020, 13:20
__Igorek__, да.

Добавлено через 1 минуту
jxstixn, ручной разбор, чтобы показать преподавателю. Бывает.
Для начала - разбейте выражение на токены по скобкам.
0
Эксперт Pascal/Delphi
 Аватар для droider
4889 / 2823 / 865
Регистрация: 04.10.2012
Сообщений: 10,268
16.07.2020, 13:24
Цитата Сообщение от dondublon Посмотреть сообщение
jxstixn, ...Для начала - разбейте выражение на токены по скобкам
Ему уже не надо. Теме больше года.
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
16.07.2020, 13:38
droider, эх, опять опоздал (голосом Громозеки).
0
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 12
16.07.2020, 13:53
мен интересно еще))) а с как это можно реализовать? я просто новичок в этом не совсем понимаю как это сделать
0
Модератор
Эксперт Python
 Аватар для Fudthhh
2696 / 1602 / 513
Регистрация: 21.02.2017
Сообщений: 4,210
Записей в блоге: 1
16.07.2020, 14:47
__Igorek__, можно:

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
import re
 
 
actions = {
  "^": lambda x, y: str(float(x)**float(y)),
  "*": lambda x, y: str(float(x) * float(y)),
  "/": lambda x, y: str(float(x) / float(y)),
  "+": lambda x, y: str(float(x) + float(y)),
  "-": lambda x, y: str(float(x) - float(y))
}
 
priority_reg_exp = r"\((.+?)\)"
action_reg_exp = r"(-?\d+(?:\.\d+)?)\s*\{}\s*(-?\d+(?:\.\d+)?)"
 
 
 
def my_eval(expresion: str) -> str:
 
    while (match := re.search(priority_reg_exp, expresion)):
        expresion: str = expresion.replace(match.group(0), my_eval(match.group(1)))
 
    for symbol, action in actions.items():
        while (match := re.search(action_reg_exp.format(symbol), expresion)):
            expresion: str = expresion.replace(match.group(0), action(*match.groups()))
 
    return expresion
 
 
exp = "(1 + 4) * (5 * (10 - 2)) / 5"
print(my_eval(exp), eval(exp))  # 40.0 40.0
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.07.2020, 14:47
Помогаю со студенческими работами здесь

Вычислить значение арифметического выражения, введённого в виде строки.
Нужно вернуть значения арифметического выражения введённого в виде строки. Объясните, пожалуйста, 1. Почему при вводе в x1 и x2...

Написать программу вычисления суммы чисел для введенного арифметического выражения в виде строки
Написать программу вычисления суммы чисел для введенного арифметического выражения в виде строки.

Вычисление арифметического выражения заданного в виде строки
Собственно вопрос в названии: возможно ли преобразовать строку с оператором в оператор? string s = '+';

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

Вычисление значения арифметического выражения представленного в текстовом виде
Уважаемые, требуется написать программу, в которой нужно с начала ввести арифметическое выражение в текстовом виде в консоль (string text...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru