WIP: math parser

This commit is contained in:
2025-02-03 17:13:32 +01:00
parent 3ffb7f8181
commit b3ac5ee075
3 changed files with 100 additions and 0 deletions

View File

@@ -0,0 +1,41 @@
Instructions
Given a mathematical expression as a string you must return the result as a number.
Numbers
Number may be both whole numbers and/or decimal numbers. The same goes for the returned result.
Operators
You need to support the following mathematical operators:
Multiplication *
Division / (as floating point division)
Addition +
Subtraction -
Operators are always evaluated from left-to-right, and * and / must be evaluated before + and -.
Parentheses
You need to support multiple levels of nested parentheses, ex. (2 / (2 + 3.33) * 4) - -6
Whitespace
There may or may not be whitespace between numbers and operators.
An addition to this rule is that the minus sign (-) used for negating numbers and parentheses will never be separated by whitespace. I.e all of the following are valid expressions.
1-1 // 0
1 -1 // 0
1- 1 // 0
1 - 1 // 0
1- -1 // 2
1 - -1 // 2
1--1 // 2
6 + -(4) // 2
6 + -( -4) // 10
And the following are invalid expressions
1 - - 1 // Invalid
1- - 1 // Invalid
6 + - (4) // Invalid
6 + -(- 4) // Invalid
Validation
You do not need to worry about validation - you will only receive valid mathematical expressions following the above rules.

View File

@@ -0,0 +1,35 @@
type Token = number | '+' | '-' | '*' | '/' | '(' | ')';
type ASTNode = {
type: string,
}
type OperatorNode = {
type: 'operator',
value: '+' | '-' | '*' | '/',
left: ASTNode,
right: ASTNode,
}
type NumberNode = {
type: 'number',
value: number,
}
type GroupNode = {
type: 'group',
value: ASTNode,
}
type NegationNode = {
type: 'negation',
value: ASTNode,
}
export function calc(expression: string): number {
// evaluate `expression` and return result
return 0;
}

View File

@@ -0,0 +1,24 @@
import { calc } from './solution';
import { expect } from "chai";
var tests: [string, number][] = [
['1+1', 2],
['1 - 1', 0],
['1* 1', 1],
['1 /1', 1],
['-123', -123],
['123', 123],
['2 /2+3 * 4.75- -6', 21.25],
['12* 123', 1476],
['2 / (2 + 3) * 4.33 - -6', 7.732],
];
describe("calc", function() {
it("should evaluate correctly", () => {
tests.forEach(function(m) {
var x = calc(m[0]);
var y = m[1];
expect(x).to.equal(y, 'Expected: "' + m[0] + '" to be ' + y + ' but got ' + x);
});
});
});