mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-07-04 07:29:47 +08:00

* Add prettier config * test: add test to check for absolute function * chore: es5 to es6 * test: add test to check mean function * test: add test for sum of digit * test: add test for factorial * test: add test for fibonnaci * test: add test for find HCF * test: add test for lcm * test: add gridget test * test: add test for mean square error * test: add test for modular binary exponentiation * test: add tests for palindrome * test: add test for pascals triangle * test: add tests for polynomial * test: add tests for prime check * test: add tests for reverse polish notation * test: add tests for sieve of eratosthenes * test: add tests for pi estimation monte carlo method * chore: move tests to test folder * chore: fix standardjs errors
34 lines
627 B
JavaScript
34 lines
627 B
JavaScript
// Wikipedia: https://en.wikipedia.org/wiki/Reverse_Polish_notation
|
|
|
|
const calcRPN = (expression) => {
|
|
const operators = {
|
|
'+': (a, b) => a + b,
|
|
'-': (a, b) => a - b,
|
|
'*': (a, b) => a * b,
|
|
'/': (a, b) => b / a
|
|
}
|
|
|
|
const tokens = expression.split(' ')
|
|
|
|
const stack = []
|
|
|
|
tokens.forEach((token) => {
|
|
const operator = operators[token]
|
|
|
|
if (typeof operator === 'function') {
|
|
const a = stack.pop()
|
|
const b = stack.pop()
|
|
|
|
const result = operator(a, b)
|
|
|
|
stack.push(result)
|
|
} else {
|
|
stack.push(parseFloat(token))
|
|
}
|
|
})
|
|
|
|
return stack.pop()
|
|
}
|
|
|
|
export { calcRPN }
|