zoukankan      html  css  js  c++  java
  • 洛谷 P1957 口算练习题

          洛谷 P1957 口算练习题

    题目描述

    王老师正在教简单算术运算。细心的王老师收集了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;
    }
    View Code
  • 相关阅读:
    在命令提示符中使用antlr
    Migrating to Rails 2.0.2
    从AJAX IN ACTION书中学用 RSS READER
    maple download url
    搜索
    发邀请在线RoR开发与部署环境www.heroku.com
    if can't use ruby in command line
    查询表中某字段有重复记录的个数
    WPF窗体自适应分辨率
    《思考,快与慢》
  • 原文地址:https://www.cnblogs.com/v-vip/p/9673236.html
Copyright © 2011-2022 走看看