我有解释波兰表示法的解释器。我拥有令牌中的所有操作和数字,并且我有一个令牌列表。因此,例如- - 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(值,值)我需要从numberTokens
给出的值应该从自身减去,但如果下一个标记是操作标记会发生什么?或者我们有- 5 - 7 2
?我不知道如何实现这样的递归函数,它会检测到第一个操作应该被执行 - 7 2 then - 5并返回结果( - 7 2),记住结果并回到先前未完成的操作。任何帮助?
听起来像你需要比解释器更多的解析器。 – stuartd
@stuartd:OP可能试图同时解析和解释。 – IAbstract
看看[this](http://codereview.stackexchange.com/questions/48632/math-equation-as-string-to-reverse-polish-notation-parser)。我在2年前写了这个作为一个学习项目。它当然可以改进,但它应该有所帮助。 – JRLambert