关于栈的简单例题,相信大家都看过,我看了例题后想自己实现下,比如(3+4)+(2*5-6)=
发现最大问题是算符的优先级怎么确定,我想到用枚举类型定义一下,这样可以比较大小,但是有些同级啊比如加减,枚举就解决不了了。我记得似乎有个函数可以映射一下,这样把加减都映射到1,乘除,,,这样,关键是我不熟悉那个函数,各位大神有什么好的思路没,指点一下吧
数据结构一书的字符优先算法例题,
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
- lx624909677 2016-03-11 06:12关注
转换成后缀表达式然后计算,比如你的那个算式对应的后缀表达式就是3 4 + 2 5 * 6 - +,然后用栈其实就是利用栈先进后除的原理,遇到数字进栈,遇到符号出栈,计算完了继续进栈
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 thinkphp6配合social login单点登录问题
- ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
- ¥15 如何在scanpy上做差异基因和通路富集?
- ¥20 关于#硬件工程#的问题,请各位专家解答!
- ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
- ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
- ¥30 截图中的mathematics程序转换成matlab
- ¥15 动力学代码报错,维度不匹配
- ¥15 Power query添加列问题
- ¥50 Kubernetes&Fission&Eleasticsearch