I am a beginner in JavaScript.
This code is supposed to evaluate a postfix expression. But it doesn't work. I think that the code is very logical and I don't really know what's wrong with it.
If someone could help me, I would be grateful!
<html>
<head>
</head>
<body>
<!-- starting javaScript -->
<script type = "text/javascript">
var postStr = "123++"; //initial postfix expression
var postArr = new Array();
postArr = postStr.split(""); //string.split() turns string into array!
for(var i=0; i<postArr.length; i++)
document.write("value"+postArr[i]+"<br>");
var stack=[];
var result;
var firstNum;
var secNum;
//var k;
for(var i=0; i<postArr.length; i++)
{
if((postArr[i]!="^")||(postArr[i]!= "+")||(postArr[i]!= "-")|| (postArr[i]!= "*")||(postArr[i]!= "/"))
{
stack.push(postArr[i]);
//document.write("length" + stack.length);
}
else if((postArr[i]=="^")||(postArr[i]== "+")||(postArr[i]== "-")||(postArr[i]== "*")||(postArr[i]== "/"))
{
if(postArr[i]=='+')
{
firstNum=stack.pop();
secNum=stack.pop();
result = secNum + firstNum;
stack.push("result = " + result);
}
else if(postArr[i]=='*')
{
firstNum=stack.pop();
secNum=stack.pop();
result = secNum * firstNum;
stack.push("result = " + result);
}
else if(postArr[i]=='/')
{
firstNum=stack.pop();
secNum=stack.pop();
result = secNum / firstNum;
stack.push("result = " + result);
}
else if(postArr[i]=='-')
{
firstNum=stack.pop();
secNum=stack.pop();
result = secNum - firstNum;
stack.push("result = " + result);
}
}
}
var finalRes=stack.pop();
document.write(finalRes);
</script>
</body>
</html>
There is some errors :
your first condition should be separated by and
(&&
) operators instead of or
since you are using negative condition
since you convert string to numbers don't forget to convert the characters into integers (with something like +postArr[i]
)
you should push the result and not a string with a comment (stack.push(result)
and not stack.push("result = " + result)
).
See this jsfiddle : http://jsfiddle.net/scaillerie/GwDTM/2/.