在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!) 创芯人才网--重磅上线啦!
查看: 1353|回复: 0

[资料] 算符优先算法

[复制链接]
发表于 2016-3-25 17:05:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x

为实现算符优先算法,可以使用两个工作栈。一个称作OPTR,用以寄存运算符;另一个称作OPND,用以寄存操作数或运算结果。算法的基本思想是:

(1)
首先置操作数栈为空栈,表达式起始符“#”为运算符栈的栈底元素;

(2)
依次读入表达式中每个字符,若是操作数则进OPND栈,若是运算符则和OPTR栈的栈顶运算符比较优先权后作为相应操作,直至整个表达式求值完毕(即OPTR栈的栈顶元素和当前读入的字符均为“#”)。

描述这个求值过程。

OperandType EvaluateExpression(){

//算术表达式求值的算符优先算法。设OPTROPND分别为运算符栈和运算数栈,

//OP为运算符集合。

InitStack(OPTR)ush(OPTR,'#');

initStack(OPND);c=getchar();

while(c!='#'||GetTop(OPTR)!='#'){

       if(!In(c,OP)){Push(OPND,c);c=getchar();}//不是运算符则进栈

       else

              switch(Precede(GetTop(OPTR),c)){

              case'<'://栈顶元素优先权低

                     Push(OPTR,c);c=getchar();

                     break;

              case'='://脱括号并接收下一字符

                     Pop(OPTR,x);c=getchar();

                     break;

              case'>'://退栈并将运算结果入栈

                     Pop(OPTR,theta);

                     Pop(OPND,b)op(OPND,a);

                     Push(OPND,Operate(a,theta,b));

                     break;

              }//switch

       }//while

       returnGetTop(OPND);

}//EvaluateExpression


凌阳教育,全国唯一一家原厂式嵌入式培训机构,专业从事嵌入式人才培训13年,最近新开课程信息安全工程师培训,想了解更多嵌入式资料下载或者是凌阳教育的动态,请访问凌阳教育官网www.sunplusedu.com

您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-9 23:28 , Processed in 0.012783 second(s), 6 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表