题目描述
王老师正在教简单算术运算。细心的王老师收集了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%的数据,输入的算式都有三个数据,第一个算式一定有三个数据。
思路:模拟,字符串
本题有许多坑点 qwq
首先,输入时,算式有两个或三个数据,需要判断
其次,若算式的答案为负数或0,需要进行特判
#include <algorithm> #include <iostream> #include <cstring> #include <cstdio> using namespace std; int n, flag; char ch; string s, x, y; void getans(char arr, string t1, string t2) { int ans, len = t1.length() + t2.length() + 2; int a = 0, b = 0, p = t1.length(), q = t2.length(); for (int i = 0; i < p; ++i) a = a * 10 + (t1[i] - '0'); for (int i = 0; i < q; ++i) b = b * 10 + (t2[i] - '0'); if (arr == '+') ans = a + b; else if (arr == '-') ans = a - b; else ans = a * b; cout << t1 << arr << t2 << '=' << ans << ' '; if (ans < 0) ans *= -1, ++len; if (ans == 0) { cout << len + 1; return ; } while (ans > 0) { ans /= 10; ++len; } cout << len; return ; } int main() { scanf("%d", &n); for (int i = 1; i <= n; ++i) { cin >> s; if (s.length() == 1) { if (s[0] == 'a') ch = '+', flag = 1; else if (s[0] == 'b') ch = '-', flag = 1; else if (s[0] == 'c') ch = '*', flag = 1; else x = s[0]; if (flag) cin >> x >> y; else cin >> y; getans(ch, x, y); } else { x = s; cin >> y; getans(ch, x, y); } if (i != n) cout << ' '; } return 0; }