我有解释波兰符号的解释器。我有令牌中的所有操作和数字,并且我有一个令牌列表。例如- - 5 4 2
,一个包含这些标记的列表:
SubtractionToken、SubtractionToken、NumberToken、NumberToken、NumberToken、STOPToken。
示例令牌:
class SubstractToken : IBinaryOperation
{
public Number Interpret(Number value1, Number value2)
{
Number c = new Number(value1.Value() - value2.Value());
return c;
}
}
class Number : IToken
{
private int value;
public Number(int val)
{
value = val;
}
public int Value()
{
return value;
}
}
所以,我无法理解如何使用递归函数来解决这个问题。因为当我 SubstractionToken.Inrerpret(value, value) 我需要从numberTokens
应该从自身中减去的值中给出值,但是如果下一个令牌是操作令牌会发生什么?或者我们有- 5 - 7 2
?我不知道如何实现这样的递归函数,它将检测到应该进行第一个操作 - 7 2 然后 - 5 和 resultof(- 7 2),记住结果并返回之前未完成的操作。有什么帮助吗?