表达式“X=A+B×(C-D)/E”的后缀表示形式可以为(11)(运算符优先级相同时,遵循左结合的原则)。

admin2009-05-15  28

问题 表达式“X=A+B×(C-D)/E”的后缀表示形式可以为(11)(运算符优先级相同时,遵循左结合的原则)。   

选项 A、XAB+CDE/-×=
B、XA+BC-DE/×=
C、XABCD-xE/+=
D、XABCDE+x-/=

答案C

解析 要把表达式从中缀表达式的形式转换成用后缀表示法表示的等价表达式,必须了解操作符的优先级和结合性。优先级或者说操作符的强度决定求值顺序;优先级高的操作符比优先级低的操作符先求值。如果所有操作符优先级一样,那么求值顺序就取决于它们的结合性。操作符的结合性定义了相同优先级操作符组合的顺序(从右至左或从左至右)。
   转换过程包括用下面的算法读入中缀表达式的操作数、操作符和括号:
   (1)初始化一个空堆栈,将结果字符串变量置空。
   (2)从左到右读入中缀表达式,每次一个字符。
   (3)如果字符是操作数,将它添加到结果字符串。
   (4)如果字符是个操作符,弹出(pop)操作符,直至遇见开括号(opening parenthesis)、优先级较低的操作符或者同一优先级的右结合符号。把这个操作符压入(push)堆栈。
   (5)如果字符是个开括号,把它压入堆栈。
   (6)如果字符是个闭括号(closing parenthesis),在遇见开括号前,弹出所有操作符,然后把它们添加到结果字符串。
   (7)如果到达输入字符串的末尾,弹出所有操作符并添加到结果字符串。
转载请注明原文地址:https://kaotiyun.com/show/9sTZ777K
0

相关试题推荐
最新回复(0)