洛谷 P1957 口算练习题

*题目描述
王老师正在教简单算术运算。细心的王老师收集了i道学生经常做错的口算题,

并且想整理编写成一份练习。 编排这些题目是一件繁琐的事情,为此他想用

计算机程序来提高工作效率。王老师希望尽量减少输入的工作量,

比如5+8的算式最好只要输入58,

输出的结果要尽量详细以方便后期排版的使用,

比如对于上述输入进行处理后输出 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;
}

猜你喜欢

转载自blog.csdn.net/AlberTesla/article/details/109275119