IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Помогите с алгоритмом решения...
Angel_thunder
сообщение 8.12.2003 10:48
Сообщение #1





Группа: Пользователи
Сообщений: 5
Пол: Мужской

Репутация: -  0  +


Помогите с задачей!
Дан текстовый файл (input.txt). В нём на языке Паскаль написано математическое выражение. Что то вроде:
A:=3*(5+2) - B;
B:=12-C;
C:=3;

Необходимо подсчитать результат выражения (верхнего!). Учительница сказала использовать какой то алгоритм ... но вот какой и где его достать не сказала  ;D.
Буду очень признателен, если подскажите, что это за алгоритм .... а ещё лучше если напишите прогу ;) ... хотя зная алгоритм прогу несложно написать!
Заранее благодарен!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
DI
сообщение 8.12.2003 11:39
Сообщение #2


Новичок
*

Группа: Пользователи
Сообщений: 41
Пол: Мужской

Репутация: -  0  +


А это возможно.Ты ничего не напутал.............


--------------------
кто ищет тот всегда найдёт
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
oleg309
сообщение 8.12.2003 14:11
Сообщение #3


профи
**

Группа: Пользователи
Сообщений: 109
Пол: Мужской

Репутация: -  1  +


Программирование линейного вычислительного процесса!


--------------------
Тело, находящееся в состоянии покоя, стремится смотреть телевизор.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
trminator
сообщение 8.12.2003 15:57
Сообщение #4


Четыре квадратика
****

Группа: Пользователи
Сообщений: 579
Пол: Мужской

Репутация: -  4  +


Я так думаю, для начала нужно получить одно арифметическое выражение 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. И так далее, пока от дерева не останется один корень


--------------------
Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
zx1024
сообщение 8.12.2003 16:39
Сообщение #5


Пионер
**

Группа: Пользователи
Сообщений: 119
Пол: Мужской

Репутация: -  0  +


Лексический анализ выражений
+
(напр.) польская запись
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Angel_thunder
сообщение 9.12.2003 9:08
Сообщение #6





Группа: Пользователи
Сообщений: 5
Пол: Мужской

Репутация: -  0  +


Большое спасибо за алгоритм .... теперь мне не придётся здавать экзамен по ИВТ! :D
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 22.06.2025 4:23
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"