关于栈的简单例题,相信大家都看过,我看了例题后想自己实现下,比如(3+4)+(2*5-6)=
发现最大问题是算符的优先级怎么确定,我想到用枚举类型定义一下,这样可以比较大小,但是有些同级啊比如加减,枚举就解决不了了。我记得似乎有个函数可以映射一下,这样把加减都映射到1,乘除,,,这样,关键是我不熟悉那个函数,各位大神有什么好的思路没,指点一下吧
数据结构一书的字符优先算法例题,
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- lx624909677 2016-03-11 06:12关注
转换成后缀表达式然后计算,比如你的那个算式对应的后缀表达式就是3 4 + 2 5 * 6 - +,然后用栈其实就是利用栈先进后除的原理,遇到数字进栈,遇到符号出栈,计算完了继续进栈
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 c程序不知道为什么得不到结果
- ¥40 复杂的限制性的商函数处理
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置