You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1.7 KiB

rpncalc

Instructions

Write a program that takes a string which contains an equation written in Reverse Polish Notation (RPN) as its first argument, that evaluates the equation, and that prints the result on the standard output followed by a newline ('\n').

Reverse Polish Notation is a mathematical notation in which every operator follows all of its operands. In RPN, every operator encountered evaluates the previous 2 operands, and the result of this operation then becomes the first of the two operands for the subsequent operator. Operands and operators must be spaced by at least one space.

The following operators must be implemented : +, -, *, /, and %.

If the string is not valid or if there is not exactly one argument, Error must be printed on the standard output followed by a newline. If the string has extra spaces it is still considered valid.

All the given operands must fit in a int.

Examples of formulas converted in RPN:

3 + 4 >> 3 4 + ((1 _ 2) _ 3) - 4 >> 1 2 _ 3 _ 4 - or 3 1 2 * _ 4 - 50 _ (5 - (10 / 9)) >> 5 10 9 / - 50 *

Here is how to evaluate a formula in RPN:

1 2 * 3 * 4 -
2 3 * 4 -
6 4 -
2

Or:

3 1 2 * * 4 -
3 2 * 4 -
6 4 -
2

Usage

student@ubuntu:~/[[ROOT]]/rpncalc$ go build
student@ubuntu:~/[[ROOT]]/rpncalc$ ./rpncalc "1 2 * 3 * 4 +" | cat -e
10$
student@ubuntu:~/[[ROOT]]/rpncalc$ ./rpncalc "1 2 3 4 +" | cat -e
Error$
student@ubuntu:~/[[ROOT]]/rpncalc$ ./rpncalc | cat -e
Error$
student@ubuntu:~/[[ROOT]]/rpncalc$ ./rpncalc "     1      3 * 2 -" | cat -e
1
student@ubuntu:~/[[ROOT]]/rpncalc$ ./rpncalc "     1      3 * ksd 2 -" | cat -e
Error$
student@ubuntu:~/[[ROOT]]/rpncalc$