Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/15: Рейтинг темы: голосов - 15, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 26.01.2012
Сообщений: 10

Калькулятор с обратной польской записью

27.01.2012, 18:00. Показов 2987. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, надо написать калькулятор с обратной польской записью. в нем должны быть действия +,-,*,\ и факториал. калькулятор работает с целыми числами. очень надо, очень важно сдать эту работу поскорее!!! помогите пожалуйста!!! я не знаю хаскел и у меня не получается это быстро написать. заранее огромное спасибо!!!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.01.2012, 18:00
Ответы с готовыми решениями:

Калькулятор обратной польской записи
Всем здравствуйте! Необходимо написать программу реализующую калькулятор обратной польской записи, нашел код в википедии, но он не...

K&R калькулятор обратной польской записи
В известной книге есть пример калькулятора в обратной польской записи. Проблема - не помещает числа в стек. На ввод числа выдает unknown...

Калькулятор на основе обратной польской записи
Преподаватель задал создать калькулятор на основе обратной польской записи, а я в Java совсем новичок. Калькулятор должен содержать...

2
Эксперт С++
 Аватар для Nameless One
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
28.01.2012, 13:43
Для выхода нажать Ctrl+C
Haskell
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import System.IO
import Data.Maybe
import Control.Monad
import qualified Data.Map as M
import Text.ParserCombinators.Parsec hiding (space)
 
data Token = Number Integer
           | BinOp (Integer -> Integer -> Integer)
           | UnOp (Integer -> Integer)
 
number, operator :: Parser Token
number = liftM (Number . read) (many1 digit) <?> "number"
 
table :: M.Map String Token
table = M.fromList [ ("+", BinOp (+))
                   , ("*", BinOp (*))
                   , ("-", BinOp (-))
                   , ("/", BinOp div)
                   , ("^", BinOp (^))
                   , ("!", UnOp fact)
                   , ("~", UnOp negate)
                   ]
 
fact :: Integer -> Integer
fact n = product [1..n]
 
operator = liftM (fromJust . (flip M.lookup) table) (choice (map string $ M.keys table))
       <?> "operator"
 
expr :: Parser [Token]
expr = do r <- skipMany space >> (number <|> operator) `sepEndBy1` (skipMany1 space)
          eof <|> ((char '\n' <?> "newline") >> return ())
          return r
    where space = oneOf " \t"
          
run :: String -> IO ()
run input = case either (Left . show) (eval []) (parse expr "expr" input) of
              Left err     -> hPutStrLn stderr err
              Right result -> print result
 
eval :: [Integer] -> [Token] -> Either String Integer
eval [x] []               = Right x
eval ys (Number x:xs)     = eval (x:ys) xs
eval (y:z:w) (BinOp x:xs) = eval (x z y : w) xs 
eval (y:ys) (UnOp x:xs)   = eval (x y : ys) xs
eval _ _                  = Left "illegal expression"
 
main :: IO ()
main = do hSetBuffering stdout NoBuffering
          forever $ putStr "> " >> hFlush stderr >> getLine >>= run
2
0 / 0 / 0
Регистрация: 26.01.2012
Сообщений: 10
28.01.2012, 19:30  [ТС]
Большое спасибо!!! но я уже сделал и сдал =) кстати очень похоже получилось на твое творение
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.01.2012, 19:30
Помогаю со студенческими работами здесь

Калькулятор на основе обратной польской нотации
Доброго времени суток! Делаю калькулятор на основе обратной польской нотации. Когда нажимаю на кнопки операций (+, -, *, /,()) выдает...

K&R, глава 4.3. калькулятор с обратной польской нотацией.
Добрый вечер. Я застопорился с примером из книги &quot;C Programming Language&quot;, 2е издание. В главе 4.3 &quot;внешние переменные&quot;...

Калькулятор с использованием обратной польской записи и стеков
Необходимо написать калькулятор используя обратную польскую запись и стеки. Программа должна обрабатывать выражения, содержащие...

Калькулятор считающий выражения обратной польской записи из файла
Здравствуйте! У меня вот такое задание &quot;Напишите программу, вычисляющую выражение в обратной польской записи. Исходное выражение...

Калькулятор обратной польской записи. Передача данных в функцию
Добрый день. Задача написания калькулятора командной строки на основе обратной польской записи. Если подробнее, то: 1. нужно...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru