mirror of
https://github.com/theoludwig/programming-challenges.git
synced 2024-12-08 00:45:29 +01:00
feat: add reverse-polish-notation challenge
This commit is contained in:
parent
390ae5b745
commit
9999d34d9a
25
challenges/reverse-polish-notation/README.md
Normal file
25
challenges/reverse-polish-notation/README.md
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
# reverse-polish-notation
|
||||||
|
|
||||||
|
Created by [@Divlo](https://github.com/Divlo) on 29 September 2020.
|
||||||
|
|
||||||
|
## Instructions :
|
||||||
|
|
||||||
|
Your job is to create a calculator which evaluates expressions in Reverse Polish notation (a mathematical notation in which operators follow their operands. It does not need any parentheses as long as each operator has a fixed number of operands).
|
||||||
|
|
||||||
|
For example expression 5 1 2 + 4 * + 3 - (which is equivalent to 5 + ((1 + 2) * 4) - 3 in normal notation) should evaluate to 14.
|
||||||
|
|
||||||
|
For your convenience, the input is formatted such that a space is provided between every token.
|
||||||
|
|
||||||
|
Empty expression should evaluate to 0.
|
||||||
|
|
||||||
|
Valid operations are +, -, *, /.
|
||||||
|
|
||||||
|
You may assume that there won't be exceptional situations (like stack underflow or division by zero).
|
||||||
|
|
||||||
|
## Source :
|
||||||
|
|
||||||
|
- [Reverse polish notation - Codewars](https://www.codewars.com/kata/52f78966747862fc9a0009ae)
|
||||||
|
|
||||||
|
## Examples :
|
||||||
|
|
||||||
|
See the `input-output.json` file for examples of input/output.
|
34
challenges/reverse-polish-notation/input-output.json
Normal file
34
challenges/reverse-polish-notation/input-output.json
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"input": [""],
|
||||||
|
"output": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["3"],
|
||||||
|
"output": 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["3.5"],
|
||||||
|
"output": 3.5
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["1 3 +"],
|
||||||
|
"output": 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["1 3 *"],
|
||||||
|
"output": 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["1 3 -"],
|
||||||
|
"output": -2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["4 2 /"],
|
||||||
|
"output": 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"input": ["5 3 + 12 8 + * 10 /"],
|
||||||
|
"output": 16
|
||||||
|
}
|
||||||
|
]
|
Loading…
x
Reference in New Issue
Block a user