数据结构与算法表达式求值报告.pptxVIP

  • 76
  • 0
  • 约5.55千字
  • 约 23页
  • 2017-01-31 发布于湖北
  • 举报
数据结构与算法表达式求值报告

表达式求值什么是表达式?任何一个表达式都有操作数、运算符和界定符组成。操作数即可以是常量,也可以是被说明为变量或常量的标识符。运算符可以分为算术运算,关系运算和逻辑运算符。界定符有左右括号和结束符等。表达式的三大类前缀表达式的计算机求值从右至左扫描表达式,遇到数字,将数字压入栈;遇到运算符,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素 operate with 次顶元素),并将结果入栈;重复上述过程直到表达式最左端,最后运算得出的值即为表达式的结果。Eg. 前缀表达式“- × + 3 4 5 6”:从右至左扫描,将6、5、4、3压入栈;(2) 遇到+运算符,因此弹出3和4(3为栈顶元素,4为次顶元素,注意与后缀表达式做比较),计算出3+4的值,得7,再将7入栈;(3) 接下来是×运算符,因此弹出7和5,计算出7×5=35,将35入栈;(4) 最后是-运算符,计算出35-6的值,即29,由此得出最终结果。可以看出,用计算机计算前缀表达式的值是很容易的。中缀表达式的计算机求值(1) 初始化两个栈:运算符栈S1和储存中间结果的栈S2;(2) 从右至左扫描中缀表达式;(3) 遇到操作数时,将其压入栈S2;(4) 遇到运算符时,比较其与S1栈顶运算符的优先级:(4-1) 如果S1为空,或栈顶运算符为右括号“)”,则直接将此运算符入栈;(4-2) 否则,若优先级比栈顶运算符的较高或相

文档评论(0)

1亿VIP精品文档

相关文档