题目描述
王老师正在教简单算术运算。细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习。 编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效率。王老师希望尽量减少输入的工作量,比如 5+85+8 的算式最好只要输入 55 和 88,输出的结果要尽量详细以方便后期排版的使用,比如对于上述输入进行处理后输出 5+8=135+8=13 以及该算式的总长度 66。王老师把这个光荣的任务交给你,请你帮他编程实现以上功能。
输入格式
第一行为数值 �i
接着的 �i 行为需要输入的算式,每行可能有三个数据或两个数据。
若该行为三个数据则第一个数据表示运算类型,aa 表示加法运算,bb 表示减法运算,cc 表示乘法运算,接着的两个数据表示参加运算的运算数。
若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。
输出格式
输出 2×�2×i 行。对于每个输入的算式,输出完整的运算式及结果,第二行输出该运算式的总长度
输入输出样例
输入 #1复制
4 a 64 46 275 125 c 11 99 b 46 64
输出 #1复制
64+46=110 9 275+125=400 11 11*99=1089 10 46-64=-18 9
说明/提示
数据规模与约定
对于 50%50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。
对于所有数据,0<�≤500<i≤50,运算数为非负整数且小于 1000010000。
//这次的博客就当是一个笔记吧
//头文件
#include<cctype>//主要用于判断是否为字符和数字是否为真的情况
//它有很多函数
isalpha();//判断是否为字符,若为字符则返回1(真),反之为0,也就是假
isalnum();//看这个函数就知道这个是判断是否为字符或者是数字的函数
这里要注意一个点,在题目中有需要判断输入为两个或者是三个,当然前面讲到个判断是否为字符可以判断,但是你要判断一个数的时候有时候是字符有时候是整数(int),那我们可以为了避免麻烦可以使用atio();函数,//这个函数功能是将字符串装换为整数的。直接这样上代码
//当然这个前提是前面我们需要判断ss【0】是否字符
string ss;
cin>>ss;
atio[ss];//这里将字符形式转换为整数形式
还有重要的一点就是,运算式的长度怎么求呢,这就变成了很大的难题,于是我们就想到了这个
sprintf//将运算符的粘贴到你所需要的字符上去
sprintf(answer,"%d+%d=%d",x,y,x+y);
如果你输入为a 12 1
answer//输出结果为12+1=12
最后这个长度就可以用strlen函数啦,代码奉上
#include<iostream>
#include<cctype>
#include<string.h>
#include<algorithm>
using namespace std;
int n,x,y;
char ss[22],ans[100],k;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%s",&ss);
if(isalpha(ss[0])){
k=ss[0];//consist
scanf("%d %d",&x,&y);
}
else {
x=atoi(ss);
scanf("%d",&y);
}
if(k=='a'){
sprintf(ans,"%d+%d=%d",x,y,x+y);
}
else if(k=='b'){
sprintf(ans,"%d-%d=%d",x,y,x-y);
}
else {
sprintf(ans,"%d*%d=%d",x,y,x*y);
}
printf("%s\n%d\n",ans,strlen(ans));
}
return 0;
}