I have been working on this infix to postfix/polis notation converter. Although, I do not feel the solution is adequate. Specifically the j (EDIT: Now called index) variable is bugging me.
Do you guys have any suggestions? Or perhaps there is a much better way to accomplish it? Or do I just worry too much?
public static string[] InfixToPostfix(string[] infixArray)
{
var stack = new Stack<string>();
var postfix = new string[infixArray.Length];
int index = 0;
string st;
for (int i = 0; i < infixArray.Length; i++)
{
if (!(MyMath.MathOperators.Contains(infixArray[i])))
{
postfix[index] = infixArray[i];
index++;
}
else
{
if (infixArray[i].Equals("("))
{
stack.Push("(");
}
else if (infixArray[i].Equals(")"))
{
st = stack.Pop();
while (!(st.Equals("(")))
{
postfix[index] = st;
index++;
st = stack.Pop();
}
}
else
{
while (stack.Count > 0)
{
st = stack.Pop();
if (RegnePrioritet(st) >= RegnePrioritet(infixArray[i]))
{
postfix[index] = st;
index++;
}
else
{
stack.Push(st);
break;
}
}
stack.Push(infixArray[i]);
}
}
}
while (stack.Count > 0)
{
postfix[index] = stack.Pop();
index++;
}
return postfix.TakeWhile(item => item != null).ToArray();
}
If you replace
array
by aStack<string>
, you don't have to keep track where you are with theindex
variable.You can then return your result with
postfixStack.ToArray()
My implementation:
Try this. It takes me a while to code this but works for every examples that i found on internet.
Here is a very basic implementation (numbers, parentheses and +-/* operators only) of the information on wikipedia about infix, postfix & the Shunting Yard algorithm. Could be neatened up & improved on, which i'll do for my own work, but I'm posting here before I customize it beyond recognition: