- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我使用简单的堆栈算法开发了一个方程解析器,该算法将处理二进制(+、-、|、&、*、/等)运算符、一元 (!) 运算符和括号。
但是,使用此方法后,所有内容都具有相同的优先级 - 无论运算符如何,它都是从左到右求值的,尽管可以使用括号强制执行优先级。
所以现在“1+11*5”返回 60,而不是预期的 56。
虽然这适用于当前项目,但我希望有一个通用例程可用于以后的项目。
为清晰起见进行了编辑:
什么是优先解析方程式的好算法?
我对一些易于实现的东西很感兴趣,并且明白我可以自己编写代码来避免可用代码的许可问题。
语法:
我不明白语法问题 - 我是手写的。它非常简单,我认为不需要 YACC 或 Bison。我只需要用诸如“2+3 * (42/13)”之类的方程来计算字符串。
语言:
我是用 C 来做的,但我对算法感兴趣,而不是特定于语言的解决方案。 C 语言足够低,因此在需要时很容易转换为另一种语言。
代码示例
我发布了 test code for the simple expression parser我上面说的。项目要求发生了变化,因此我从不需要针对性能或空间优化代码,因为它没有并入项目中。它是原始的冗长形式,应该很容易理解。如果我在运算符优先级方面进一步处理它,我可能会选择 the macro hack因为它与程序的其余部分简单匹配。不过,如果我在实际项目中使用它,我会选择更紧凑/更快速的解析器。
相关问题
-亚当
最佳答案
shunting yard algorithm是正确的工具。维基百科对此真的很困惑,但基本上算法是这样工作的:
比如说,您想计算 1 + 2 * 3 + 4。凭直觉,您“知道”必须先计算 2 * 3,但您如何获得这个结果?关键是要意识到,当您从左到右扫描字符串时,您将在 后面 的运算符具有较低(或等于)优先级时评估运算符。在示例的上下文中,这是您想要执行的操作:
你是如何实现的?
您想要两个堆栈,一个用于数字,另一个用于运算符。您一直将数字压入堆栈。您将每个新运算符与堆栈顶部的运算符进行比较,如果堆栈顶部的运算符具有更高的优先级,则将其从运算符堆栈中弹出,将操作数从数字堆栈中弹出,应用运算符并推送结果到数字堆栈上。现在您重复与栈顶运算符的比较。
回到这个例子,它是这样工作的:
N = [ ]操作 = [ ]
*
。 N = [1 2], Ops = [+ *]*
3,并将结果压入 N。N = [1 6], Ops = [+]+
是左关联的,因此您也想弹出 1、6 并执行 +。 N = [7],操作数 = []。嗯,这并不难,不是吗?而且它不调用任何语法或解析器生成器。
关于algorithm - 具有优先级的方程(表达式)解析器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28256/
int x = 1; System.out.println( x++ + x++ * --x ); 上面的代码打印出“5”,但我不明白怎么办?我一直为最后一个 x 取零,然后乘以仍然为 0 的第二个
我现在正在尝试使用 Preference 类 首选项 pfrOfThis = Preferences.userNodeForPackage(this) 出现错误: “类 java.util.prefs
用下面的代码 import sys print "Hello " + sys.argv[1] if len(sys.argv) > 1 else "Joe" + "." 当我运行时 python he
我的网页包含: td { padding-left:10px; } 引用的样式表包含: .rightColumn * {margin: 0; padding: 0;} 我在 rightc
使用 JPA 我有一个关于 CascadeTypes 的问题。 例如: @ManyToMany(fetch=FetchType.LAZY, cascade={CascadeType.PERSIST,
下面的“括号”是怎么写的? val words = List("foo", "bar", "baz") val phrase = "These are upper case: " + words ma
我只是想知道,对于以下代码,编译器是否单独使用关联性/优先级或其他一些逻辑来评估。 int i = 0, k = 0; i = k++; 如果我们根据关联性和优先级进行评估,postfix ++具有比
我设置了一个 Azure FrontDoor 服务,以主/备份类型的方式将流量分配给两个 API 管理服务。就像我希望所有流量都流向我的主要 APIM 服务一样,如果我碰巧关闭该服务(假装中断),那么
这是一个简单的 CSS: /* Smartphones (portrait and landscape) ----------- */ @media only screen and (min-devi
我设置了一个 Azure FrontDoor 服务,以主/备份类型的方式将流量分配给两个 API 管理服务。就像我希望所有流量都流向我的主要 APIM 服务一样,如果我碰巧关闭该服务(假装中断),那么
来自 Programming Perl pg 90,他说: @ary = (1, 3, sort 4, 2); print @ary; 排序右侧的逗号在排序之前求值,而左侧的逗号在排序之
+----+------------+------+ | id | title | lang | +----+------------+------+ | 1 | title 1 EN |
如何使用 Java 获取 DiffServe 代码点 (DSCP) 整数的优先级部分?我预计它涉及位移位,但由于某种原因,我似乎无法获得我期望的值。 最佳答案 假设我理解正确,只需向右执行 3 位逻辑
我有下一个运行良好的 js 函数: $(function () { $(".country").click(function () { var countries = Arra
int a[3]={10,20,30}; int* p = a; cout << *p++ << endl; 根据 wikipedia ,后缀++的优先级高于解引用,*p++应该先运行p++再解引用结
我想在优先读取归档后解决这种类型的表达式 2+3/5*9+3-4 这是我尝试解决该任务的代码我该如何解决这个问题 while ( !inputFile.eof() ) { getline( inp
我正在玩 Rhino 并注意到这种奇怪的行为似乎是运算符优先级: js> {}+{} NaN js> ''+{}+{} [object Object][object Object] js> ''+({
我想遍历文件列表并检查它们是否存在,如果文件不存在则给出错误并退出。我写了下面的代码: FILES=( file1.txt file2.txt file3.txt ) for file in ${FI
我正在执行级联 SELECT: SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3 => If nothing found, try: SELECT * F
即将参加考试,我正在参加之前的考试。 问题: 当两个或多个样式表规则应用于同一元素时,以下哪种类型的规则将优先? 一个。任何来自浏览器的声明 b.有用户来源的正常声明 C。作者来源正常声明 d.文档级
我是一名优秀的程序员,十分优秀!