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

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

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

 
 Ответить  Открыть новую тему 
> Задача по теме "Ссылочные переменные, задача на ст, задача на стек
sergeant
сообщение 25.06.2005 4:55
Сообщение #1





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

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


Люди помогите нужно решить задачу к экзамену, не знаю как сделать.

Используя стек, решить следующую задачу:
В текстовом файле f записано без ошибок формула следующего вида:
<формула>::=<цифра>| М (<формула>, <формула>) | m <формула>, <формула>)
<цифра>::=0| 1| 2| 3| 4| 5| 6| 7| 8| 9,
где М обозначает функцию max, а m – min. Вычислить как целое число значение данной формулы. Например, M (5, m(6, 8)) = 6.
Заранее спасибо...
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 25.06.2005 9:33
Сообщение #2


Гость






Самый простой вариант - берешь 2 стека (один будет хранить код операции, второй - сами операнды), и просто разбираешь строку:

Цитата
пока строка не закончилась
  читать следующий элемент (число в виде строки или символ)
    если символ "M" или "m", то занести его в стек операций
    если число, то занести его в стек операндов
    если символ "(" или "," то ничего не делать
    если ")", то взять 2 операнда из стека операндов и произвести
      над ними операцию, которую взять из стека операций.
      результат занести в стек операндов


По окончании работы этого алгоритма в стеке операндов останется одно значение, которое и будет результатом выражения...
 К началу страницы 
+ Ответить 
volvo
сообщение 25.06.2005 18:35
Сообщение #3


Гость






Ну, а сама программа будет выглядеть как-то вот так (чтение строки и удаление из нее всех пробелов придется добавить самостоятельно, т.к. если из обрабатываемой строки НЕ удалить все пробелы, программа завершится переполнением стека).


Прикрепленные файлы
Прикрепленный файл  min_max.pas ( 2.87 килобайт ) Кол-во скачиваний: 181
 К началу страницы 
+ Ответить 
sergeant
сообщение 1.07.2005 13:31
Сообщение #4





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

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


Спасибо большое за то, что не пожалел своего времени...
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 



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