From bfc17ab2dc9eac4607a664197a966bfbfe3f90dd Mon Sep 17 00:00:00 2001 From: Raj Date: Sat, 20 Jul 2024 14:20:42 +0530 Subject: [PATCH] fix Cannot evaluate for power operator (^) #15 --- ds.js | 29 ++++------------------------- 1 file changed, 4 insertions(+), 25 deletions(-) diff --git a/ds.js b/ds.js index 22c5e31..12ad352 100644 --- a/ds.js +++ b/ds.js @@ -238,27 +238,7 @@ function postfixEval(expression) { const a = stack.pop(); const b = stack.pop(); - let result; - switch (char) { - case "+": - result = `(${b} + ${a})`; - break; - case "-": - result = `(${b} - ${a})`; - break; - case "*": - result = `(${b} * ${a})`; - break; - case "/": - result = `(${b} / ${a})`; - break; - case "^": - result = `(${b} ** ${a})`; // Exponentiation - break; - default: - throw new Error(`Unknown operator: ${char}`); - } - + let result = `(${b} ${char} ${a})`; stack.push(result); } @@ -270,13 +250,12 @@ function postfixEval(expression) { let _tresult = `${finalResult}`; try { - _tresult += ` = ${eval(finalResult)}`; + _tresult += ` = ${eval(finalResult.replace(/\^/g, "**"))}`; } catch (error) { _tresult += " = Error"; } table.s[table.s.length - 1] = _tresult; - return table; } @@ -306,8 +285,7 @@ function prefixEval(expression) { const b = stack.pop(); // Create the expression with current operator - const result = `(${a}${char}${b})`; - + let result = `(${b} ${char} ${a})`; // Push the result back to stack stack.push(result); } @@ -326,6 +304,7 @@ function prefixEval(expression) { _tresult += ` = ${eval(finalResult.replace(/\^/g, "**"))}`; } + _tresult = _tresult.replace("**", "^"); table.s[table.s.length - 1] = _tresult; return table; }