口算练习题

P1957 口算练习题

时间限制: 1.00s    内存限制: 512.00MB

 复制 Markdown

 中文 退出 IDE 模式

题目描述

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

输入格式

第一行一个整数 i

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

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

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

输出格式

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

#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main(){
    int i;
    cin>>i;
    vector<vector<string>> cac(i,vector<string>(3));
    for(int m = 0;m<i;m++){
        string h;
        cin>>h;
        if(h=="a"||h=="b"||h=="c"){
            cac[m][0] = h;
            cin>>cac[m][1]>>cac[m][2];
        }
        else{
            cac[m][0] = cac[m-1][0];
            cac[m][1] = h;
            cin>>cac[m][2];
        }
    }
    for(int m = 0;m<i;m++){
        if(cac[m][0] == "a"){
            string str1 = cac[m][1]+'+'+cac[m][2]+'='+to_string(stoi(cac[m][1])+stoi(cac[m][2]));
            cout<<str1<<endl<<str1.length()<<endl;
        }
        else if(cac[m][0] == "b"){
            string str1 = cac[m][1]+'-'+cac[m][2]+'='+to_string(stoi(cac[m][1])-stoi(cac[m][2]));
            cout<<str1<<endl<<str1.length()<<endl;
        }
         else if(cac[m][0] == "c"){
            string str1 = cac[m][1]+'*'+cac[m][2]+'='+to_string(stoi(cac[m][1])*stoi(cac[m][2]));
            cout<<str1<<endl<<str1.length()<<endl;
        }
    }
    return 0;
}
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇