*题目描述
王老师正在教简单算术运算。细心的王老师收集了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*
My Answer Code:
/*
Author:Albert Tesla Wizard
Time:2020/10/25 16:23
*/
#include<bits/stdc++.h>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int t;
cin>>t;
vector<vector<string>>s((t+1),vector<string>(4));
for(int i=1;i<=t;i++)
{
cin>>s[i][1];
if(s[i][1]=="a"||s[i][1]=="b"||s[i][1]=="c")
{
cin>>s[i][2]>>s[i][3];
}
else
{
cin>>s[i][2];
}
}
for(int i=1;i<=t;i++)
{
if(s[i][1]=="a")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"+"<<s[i][3]<<"="<<a+b<<'\n';
string s1=to_string(a+b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
else if(s[i][1]=="b")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"-"<<s[i][3]<<"="<<a-b<<'\n';
string s1=to_string(a-b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
else if(s[i][1]=="c")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"*"<<s[i][3]<<"="<<a*b<<'\n';
string s1=to_string(a*b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
else
{
s[i][3]=s[i][2];
s[i][2]=s[i][1];
s[i][1]=s[i-1][1];
if(s[i][1]=="a")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"+"<<s[i][3]<<"="<<a+b<<'\n';
string s1=to_string(a+b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
else if(s[i][1]=="b")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"-"<<s[i][3]<<"="<<a-b<<'\n';
string s1=to_string(a-b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
else if(s[i][1]=="c")
{
int a=stoi(s[i][2],0,10);
int b=stoi(s[i][3],0,10);
cout<<s[i][2]<<"*"<<s[i][3]<<"="<<a*b<<'\n';
string s1=to_string(a*b);
int len=s[i][2].length()+s[i][3].length()+2+s1.length();
cout<<len<<'\n';
}
}
}
return 0;
}
洛谷 P1957 口算练习题
猜你喜欢
转载自blog.csdn.net/AlberTesla/article/details/109275119
今日推荐
周排行