两种方法解决口算练习题-创新互联
- 口算练习题
- 题目描述
- 输入格式
- 输出格式
- 样例 #1
- 样例输入 #1
- 样例输出 #1
- 提示
- 题解:
- 大佬的代码:
王老师正在教简单算术运算。细心的王老师收集了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 样例输入 #14
a 64 46
275 125
c 11 99
b 46 64
样例输出 #164+46=110
9
275+125=400
11
11*99=1089
10
46-64=-18
9
提示数据规模与约定
对于 50 % 50\% 50% 的数据,输入的算式都有三个数据,第一个算式一定有三个数据。
对于所有数据,
0
<
i
≤
50
0
题解:
我将分为四部分求解:
- 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';
}
}
- 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++;
}
}
- 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<=0;i--){
printf("%c",d[i]);
}
printf("\n");
cout<
- 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;
}
#include#include#includeusing 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<=0;i--){printf("%c",d[i]);
}
printf("\n");
cout<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方法将字符转整数;
#include#include#includeusing namespace std;
int main(){int n;
char a;
int c,d;
char b[100],s[100];
cin>>n;
for(int i=0;icin>>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<
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
网页标题:两种方法解决口算练习题-创新互联
分享链接:http://myzitong.com/article/pccop.html