洛谷P1957 口算练习题

题目描述 王老师正在教简单算术运算。细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习。 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效率。王老师希望尽量减少输入的工作量,比如5+8的算式最好只要输入5和8,输出的结果要尽量详细以方便后期排版的使用,比如对于上述输入进行处理后输出 5+8=13 以及该算式的总长度6。王老师把这个光荣的任务交给你,请你帮他编程实现以上功能。
输入格式 第一行为数值i
接着的i行为需要输入的算式,每行可能有三个数据或两个数据。
若该行为三个数据则第一个数据表示运算类型,a表示加法运算,b表示减法运算,c表示乘法运算,接着的两个数据表示参加运算的运算数。
若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。
输出格式 输出2i行。对于每个输入的算式,输出完整的运算式及结果,第二行输出该运算式的总长度
输入
4
a 64 46
275 125
c 11 99
b 46 64
输出
64+46=110
9
275+125=400
11
11
99=1089
10
46-64=-18
9
0<i<=50
运算数为非负整数且小于10000
对于50%的数据,输入的算式都有三个数据,第一个算式一定有三个数据。
这题刚看吓一跳,发现有以下难点(主要本蒟蒻想吐槽下):
1,输入很难,有两个数据 有三个数据,所以要考虑输入之前的情况
2. 输出很难,需要最后输出,想了本蒟蒻好多时间,我是利用三个数组,一个字符串数组,两个整形数组才处理(做完 看到大佬们都用什么缓存区,不愧是大佬啊)
我这算个想我这种蒟蒻看的吧,相信能看懂吧,不说了贴代码

#include<bits/stdc++.h>//万能头 
using namespace std;
string s[1000];//存储等式的字符串数组 
int size[100];//存储等式长度的数组 
int p[1000];//存储等式答案的数组 
int m,k;
string a[1000];//存储输入的每行开头字符串数组(因为可能输入一串数字 所以用字符串数组) 
int i,j,u;
int add(string b,string c){
   //加 减 乘代码差不多就解释这一个  b c是存储输入的等式系数的字符串 
         s[j]+=b; 
   s[j]+='+';
   s[j]+=c;
   s[j]+='=';//将字符串等式放入字符串数组里 
   m=atoi(b.c_str());
   k=atoi(c.c_str());//将字符串转化成整形 方便计算 
   p[j]=m+k;
   m=m+k;
   if(m>0){
   //判断答案的长度 
   while(m>0){
   
    m=m/10;
    u++;
   }}
   else if(m==0){
   
    u=1;
   }
   
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值