高分,在线等!!!!!急!!大家请帮忙!

LY198196900 2004-08-27 11:14:10
请问一下各位:
象这样的表达式"10*20+30-40/20",如何对它进行拆分。
我的想法是一个一个的找到优先级最低的"+,-",那左边的串,肯定不会再有"+,-",然后右边用递归来实现,最终的拆分。接着进行运算。思路有一点,但具体做起来,的确有点难度。请大家指教指教。
最好给点源代码。谢谢!
...全文
131 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
LY198196900 2004-08-27
  • 打赏
  • 举报
回复
我想请问一下,你的思路是我的差不多吗?如果是的话,那可以啊,谢谢。
lb2261981 2004-08-27
  • 打赏
  • 举报
回复
哈哈,我最近刚刚完成一个计算器的类。功能比拟的多一些,不知道你要不要。有800多行把。
LY198196900 2004-08-27
  • 打赏
  • 举报
回复
还是不懂啊,我是初学者呢。有没有简单一点的啊,麻烦了,谢谢。
LY198196900 2004-08-27
  • 打赏
  • 举报
回复
谢谢你,提供的源代码,不过太难了,我看不懂。能够解释一下关键的地方吗?
lixiaosan 2004-08-27
  • 打赏
  • 举报
回复
其实就是把中缀表达式变为后缀表达式。然后计算就可以了
lixiaosan 2004-08-27
  • 打赏
  • 举报
回复
http://www.vckbase.com/code/general/misc/expresscal.rar
LY198196900 2004-08-27
  • 打赏
  • 举报
回复
请问能不能说详细点啊,光这样我还是不会的啊。麻烦了,谢谢!
内存泄漏 2004-08-27
  • 打赏
  • 举报
回复
按运算符优先级的反序,从字符串右边开始递归。
lu1172101275 2004-08-27
  • 打赏
  • 举报
回复
用两个栈来实现:比如栈1放数据,栈2放运算符,(从左到右,碰到数,压栈1,碰到符,压栈2)
每压一个符号时,与下一个符号y比较(用一指针指向下符号,但它还没在栈里,它也可以为空),
并操作如下:
如果y运算符优先级小或一样,就弹出栈1两数,并用当前符号运算;结果压栈1,当前运算符弹出栈. 如果y运算符优先级大,数压栈,当前符号也压栈. 如此重复..
lb2261981 2004-08-27
  • 打赏
  • 举报
回复
晕,我用的是逆波兰的思想,实现上少有不同。

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧