![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
Angel_thunder |
![]()
Сообщение
#1
|
![]() Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: ![]() ![]() ![]() |
Помогите с задачей!
Дан текстовый файл (input.txt). В нём на языке Паскаль написано математическое выражение. Что то вроде: A:=3*(5+2) - B; B:=12-C; C:=3; Необходимо подсчитать результат выражения (верхнего!). Учительница сказала использовать какой то алгоритм ... но вот какой и где его достать не сказала ;D. Буду очень признателен, если подскажите, что это за алгоритм .... а ещё лучше если напишите прогу ;) ... хотя зная алгоритм прогу несложно написать! Заранее благодарен! |
![]() ![]() |
DI |
![]()
Сообщение
#2
|
Новичок ![]() Группа: Пользователи Сообщений: 41 Пол: Мужской Репутация: ![]() ![]() ![]() |
А это возможно.Ты ничего не напутал.............
-------------------- кто ищет тот всегда найдёт
|
oleg309 |
![]()
Сообщение
#3
|
![]() профи ![]() ![]() Группа: Пользователи Сообщений: 109 Пол: Мужской Репутация: ![]() ![]() ![]() |
Программирование линейного вычислительного процесса!
-------------------- Тело, находящееся в состоянии покоя, стремится смотреть телевизор.
|
trminator |
![]()
Сообщение
#4
|
Четыре квадратика ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 579 Пол: Мужской Репутация: ![]() ![]() ![]() |
Я так думаю, для начала нужно получить одно арифметическое выражение 3*(5+2)-(12-3), затем его разобрать.
Как разбирать: назначь каждой арифметической операции какой-то приоритет. Например: + = 1 - = 2 * = 3 / = 4 Скобки пусть этот приоритет, допустим, увеличивают в 10 раз. Получится: 3 3 5 10 2 2 12 20 3, где полужирным выделены коды операций. Потом строишь дерево разбора (двоичное, разумеется) этого выражения: находишь операцию с самым маленьким кодом (в этом примере это "-" - код 2), это будет вершина дерева. Левым поддеревом будет та часть, что слева, правым - та, что справа. Так повторяешь для каждого поддерева, пока все выражение не будет разобрано. Потом вычислить выражение очень просто: берешь какой-либо узел-операцию с двумя листьями-операндами, листья прибиваешь, а узел делаешь операндом. Получается такое дерево: [img]http://www.cs.karelia.ru/~pevgonen/sample.gif[/img] рисунок ^ можно узел-оператор со знаком + заменить на операнд 7, а листья прибить. Аналогично и узел, в котором из 12 вычитается 3 - заменяем его на 9. И так далее, пока от дерева не останется один корень -------------------- Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала |
zx1024 |
![]()
Сообщение
#5
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 119 Пол: Мужской Репутация: ![]() ![]() ![]() |
Лексический анализ выражений
+ (напр.) польская запись |
Angel_thunder |
![]()
Сообщение
#6
|
![]() Группа: Пользователи Сообщений: 5 Пол: Мужской Репутация: ![]() ![]() ![]() |
Большое спасибо за алгоритм .... теперь мне не придётся здавать экзамен по ИВТ! :D
|
![]() ![]() |
![]() |
Текстовая версия | 22.06.2025 21:05 |