口算练习题-题解

题目描述

王老师正在教简单算术运算。细心的王老师收集了i道学生经常做错的口算题,并且想整理编写成一份练习。
编排这些题目是一件繁琐的事情,为此他想用计算机程序来提高工作效率。
王老师希望尽量减少输入的工作量,比如5+8的算式最好只要输入5和8,输出的结果要尽量详细以方便后期排版的使用,比如对于上述输入进行处理后输出 5+8=13 以及该算式的总长度6。
王老师把这个光荣的任务交给你,请你帮他编程实现以上功能。

输入格式:

第一行为数值i
接着的i行为需要输入的算式,每行可能有三个数据或两个数据。
若该行为三个数据则第一个数据表示运算类型,a表示加法运算,b表示减法运算,c表示乘法运算,接着的两个数据表示参加运算的运算数。
若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。

输出格式:

输出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

说明

0<i<=50
运算数为非负整数且小于10000
对于50%的数据,输入的算式都有三个数据,第一个算式一定有三个数据。

思路

模拟

字符串和数字的转换也可以用atoi和itoa

AC代码

#include<bits/stdc++.h>
using namespace std;
int n;
string c;
struct YunSuan{
	char kind;
	int a;
	int b;
	string SuanSi;
	int len;
}s[55];
char FuHao(char d){
	switch(d){
		case'a':return '+';
		case'b':return '-';
		case'c':return '*';
	}
}
string ItoS(int m){
	string s1="\0",s2="\0";
	if(m==0)
		return "0";
	else if(m>0){
		while(m!=0){
			int b=m%10;
			s1+=(b+'0');
			m/=10;
		}
		int z=s1.length();
		for(int i=0; i<z; i++)
			s2+=s1[z-i-1];
		return s2;
	}
	else if(m<0){
		m=abs(m);
		while(m!=0){
			int b=m%10;
			s1+=(b+'0');
			m/=10;
		}
		int z=s1.length();
		for(int i=0; i<z; i++)
			s2+=s1[z-i-1];
		return '-'+s2;
	}
}
int StoI(string p){
	int a=0;
	for(int i=0; i<p.length(); i++){
		a*=10;
		a+=p[i]-'0';
	}
	return a;
}
int Nice(char q,int x,int y){
	switch(q){
		case'+':
			return x+y;
		case'-':
			return x-y;
		case'*':
			return x*y;
	}
}
int main(){
	cin>>n;
	for(int i=0; i<n; i++){
		cin>>c;
		if(c>="a" && c<="c"){
			s[i].kind=c[0];
			cin>>s[i].a>>s[i].b;
			s[i].SuanSi=ItoS(s[i].a)+FuHao(s[i].kind)+ItoS(s[i].b)+'='+ItoS(Nice(FuHao(s[i].kind),s[i].a,s[i].b));
			s[i].len=s[i].SuanSi.length();
		}
		else{
			s[i].kind=s[i-1].kind;
			s[i].a=StoI(c);
			cin>>s[i].b;
			s[i].SuanSi=ItoS(s[i].a)+FuHao(s[i].kind)+ItoS(s[i].b)+'='+ItoS(Nice(FuHao(s[i].kind),s[i].a,s[i].b));
			s[i].len=s[i].SuanSi.length();
		}
	}
	for(int i=0; i<n; i++){
		cout<<s[i].SuanSi<<'\n';
		cout<<s[i].len<<'\n';
	}
	return 0;
}

/*

Input:

 4
 a 64 46
 275 125
 c 11 99
 b 46 64


Output:

 64+46=110
 9
 275+125=400
 11
 11*99=1089
 10
 46-64=-18
 9

*/

有问题或有更好的办法请指出

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值