gpt4 book ai didi

c++ - 解析树中的一元和二元减法

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:32:17 24 4
gpt4 key购买 nike

我正在创建一个包含类似于

的表达式的解析树

3 - 4 * 8

8 * -5

-(10 * 1)

我需要一种方法来区分一元减号和二元减号。我的语法现在的方式是先达到二进制减号,但我正在考虑更改它并添加一个标志变量来保存最后一个变量。

例如:如果是 5 - 6

标志持有 5,如果它看到负号并且标志是一个数字,则跳过一元并转到二进制。

但是我不确定如何在 C++ 中实现它

如有任何帮助,我们将不胜感激。

谢谢

最佳答案

实现解析器最简单的方法是通过Recursive Descent的方法。 .确保给二元减号一个比一元减号更高的优先级,就像在引用的站点中一样:

 E -->  | E "+" E
| E "-" E
| "-" E
| E "*" E
| E "/" E
| E "^" E
| "(" E ")"
| v

关于c++ - 解析树中的一元和二元减法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10556381/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com