两种方法解决口算练习题

口算练习题

题目描述

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

输入格式

第一行为数值 i i i

接着的 i i i 行为需要输入的算式,每行可能有三个数据或两个数据。

若该行为三个数据则第一个数据表示运算类型, a \texttt a a 表示加法运算, b \texttt b b 表示减法运算, c \texttt c c 表示乘法运算,接着的两个数据表示参加运算的运算数。

若该行为两个数据,则表示本题的运算类型与上一题的运算类型相同,而这两个数据为运算数。

输出格式

输出 2 × i 2\times i 2×i 行。对于每个输入的算式,输出完整的运算式及结果,第二行输出该运算式的总长度

样例 #1

样例输入 #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\% 50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。

对于所有数据, 0 < i ≤ 50 0<i\leq 50 0<i50,运算数为非负整数且小于 10000 10000 10000


题解:

我将分为四部分求解:

  1. change函数:主要是数字转化为字符;
void change(int sum){
   int t=0,flag=0;
   if(sum<0){
   flag=1;
   sum=-sum;
   }
   while(sum/10!=0){
   	d[t]=sum%10+'0';
   	sum/=10;
   	t++;
   }
   d[t]=sum+'0';
   t++;
   if(flag){
   	d[t]='-';
   	t++;
   	d[t]='\0';
   }
   else {
   	d[t]='\0';
   }
}
  1. exchange函数:将字符转化为整数;
void exchange(char *b){
	int k=0;
	b1=0;
	for(int i=strlen(b)-1;i>=0;i--){
		b1+=(b[i]-'0')*pow(10,k);
		k++;
	}
}
  1. compute函数:计算并输出;
void compute(char *b,char *c,char mark){
	exchange(b);
	int k=b1;
	exchange(c);
	int k1=b1;
	int sum=0;
	if(mark=='a'){
		sum=k+k1;
	}
	else if(mark=='b'){
		sum=k-k1;
	}
	else {
		sum=k*k1;
	}
	change(sum);
	cout<<b<<mark1[mark-'a']<<c<<"=";
	for(int i=strlen(d)-1;i>=0;i--){
		printf("%c",d[i]);
	}
	printf("\n");
	cout<<strlen(b)+strlen(c)+strlen(d)+2<<endl;
}

  1. main函数,式子的输入;
int main(){
	int n;
	cin>>n;
	int t=n;
	char mark;
	while(t--){
	cin>>a;
	if(a[0]<'0'||a[0]>'9'){
		mark=a[0];
		cin>>b;
		cin>>c;
	compute(b,c,mark);	
	}
	else{
		cin>>b;
		compute(a,b,mark);
	}
a[0]='\0';
b[0]='\0';
c[0]='\0';
d[0]='\0';	
}
return 0;
}
转化字符到整数
input
导入compute函数
转化整数到字符
exchange函数
compute函数
stdin
main函数
change函数
output
#include<iostream>
#include<cstring>
#include<cmath>
using namespace std;
char a[100],b[100],c[100],d[100],mark1[4]={"+-*"};
int b1=0;
void change(int sum){
	int t=0,flag=0;
	if(sum<0){
	flag=1;
	sum=-sum;
	}
	while(sum/10!=0){
		d[t]=sum%10+'0';
		sum/=10;
		t++;
	}
	d[t]=sum+'0';
	t++;
	if(flag){
		d[t]='-';
		t++;
		d[t]='\0';
	}
	else {
		d[t]='\0';
	}
}
void exchange(char *b){
	int k=0;
	b1=0;
	for(int i=strlen(b)-1;i>=0;i--){
		b1+=(b[i]-'0')*pow(10,k);
		k++;
	}
}
void compute(char *b,char *c,char mark){
	exchange(b);
	int k=b1;
	exchange(c);
	int k1=b1;
	int sum=0;
	if(mark=='a'){
		sum=k+k1;
	}
	else if(mark=='b'){
		sum=k-k1;
	}
	else {
		sum=k*k1;
	}
	change(sum);
	cout<<b<<mark1[mark-'a']<<c<<"=";
	for(int i=strlen(d)-1;i>=0;i--){
		printf("%c",d[i]);
	}
	printf("\n");
	cout<<strlen(b)+strlen(c)+strlen(d)+2<<endl;
}

int main(){
	int n;
	cin>>n;
	int t=n;
	char mark;
	while(t--){
	cin>>a;
	if(a[0]<'0'||a[0]>'9'){
		mark=a[0];
		cin>>b;
		cin>>c;
	compute(b,c,mark);	
	}
	else{
		cin>>b;
		compute(a,b,mark);
	}
a[0]='\0';
b[0]='\0';
c[0]='\0';
d[0]='\0';	
}
return 0;
}

大佬的代码:

同样他是采用sscanf,sprintf方法将字符转整数;

input:字符变整形
整数变字符型
stdin
sscanf
sprintf
output

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int main(){
	int n;
	char a;
	int c,d;
	char b[100],s[100];
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>b;
	if(b[0]<'0'||b[0]>'9'){
		a=b[0];
		cin>>c>>d;
	}	
	else{
		sscanf(b,"%d",&c);//将b转化为c的int型;
		cin>>d; 
	}
	memset(s,0,sizeof(s));
	if(a=='a'){
		sprintf(s,"%d+%d=%d",c,d,c+d);
	}
	else if(a=='b'){
		sprintf(s,"%d-%d=%d",c,d,c-d);
	}
	else{
		sprintf(s,"%d*%d=%d",c,d,c*d);
	}
	cout<<s<<endl<<strlen(s)<<endl;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值