【TSOJ课程】06 1373 计算器1

课程29_06 1373 计算器1


题目:

题目描述:

给定一行表达式,中间没有空格,输出表达式的计算结果。测试数据保证在 int 范围之内。
这是简单的一个题目,只涉及加法和减法。

输入描述:

一行表达式

输出描述:

表达式的计算结果

样例输入:

12+21-0

样例输出:

33


解析:

感动中国,终于有一道像样的算法题了(虽然好像不是很难)

最简单的计算表达式题。因为是在是非常简单,没有括号、乘除,所以就没有计算优先度这种问题,从左往右算就可以了,所以甚至连后缀表达式都不需要拿出来。

这里我用了一个有点类似于栈的东西,没有接触过栈的同学可以感受一下这个感觉。

思路非常简单:首先读取表达式,然后从前往后读取。表达式涉及了两种运算——加法和减法。但是其实减法不就是加上了一个负数吗。所以我将减法理解为加法,而减号理解为负号,这样我们只需要一路加下去就可以了。

什么意思呢,比如21+12-5,正常的理解就是先把21+12算出来,然后把结果减掉5。但是我不这么理解,我把他理解为三个数字:21,+12,-5,然后求他们的和。


解题:

首先说思路:

读取了表达式exp以后,我申请了一个变量temp,类型是string。这个temp是用来暂时存储一些字符串的。我们把输入给的字符串从头开始处理,如果是数字,我们就把他追加到temp里去,直到碰到一个符号(+或-),我们把temp里的东西转化为数字,加到res里去,然后清空temp,并把碰到的这个符号加到temp里去。

光这么讲可能有点难理解,举个例子,21+13-5:

刚开始读2,然后读1,这个时候temp里是“21”,res是0。继续往下,这个时候读取到+了,把temp转化为数字21,加到res里,然后清空temp,并且把刚刚碰到的加号放进去,这个时候变量的情况是这样的&

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值