zoukankan      html  css  js  c++  java
  • NOIP 2013 表达式求值

    NOIP 2013 表达式求值

    洛谷传送门

    JDOJ传送门

    Description

    给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。

    Input

    输入仅有一行,为需要你计算的表达式,表达式中只包含数字、加法运算符“+”和乘法运算符“”,且没有括号,所有参与运算的数字均为0到2^31-1之间的整数。输入数据保证这一行只有0~9、+、这12种字符。

    Output

    输出只有一行,包含一个整数,表示这个表达式的值。注意:当答案长度多于4位时,请只输出最后4位,前导0不输出。

    Sample Input

    Sample Input I: 1+13+4 Sample Input II: 1+12345678901 Sample Input III: 1+1000000003*1

    Sample Output

    Sample Output I: 8 Sample Output II: 7891 Sample Output III: 4

    HINT

    【样例说明】

    样例1计算的结果为8,直接输出8。

    样例2计算的结果为1234567891,输出后4位,即7891。

    样例3计算的结果为1000000004,输出后4位,即4。

    【数据范围】

    对于30%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100;

    对于80%的数据,0≤表达式中加法运算符和乘法运算符的总数≤1000;

    对于100%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100000。


    题解:

    一道模拟题。

    直接依题意模拟即可。注意数据范围要开Longlong,然后输入最后四位就直接模10000就得了。

    代码:

    #include<bits/stdc++.h>
    using namespace std;
    bool flag=1;
    int main()
    {
        long long num,sum=0,cj;
        char ch=0,xg;
        while(flag)
        {
            scanf("%lld",&num);
            flag=scanf("%c",&xg)==1?true:false;
            if(ch==0)
    			cj=num;
            if(ch=='+')
    			sum=(sum+cj)%10000,cj=num;
            if(ch=='*')
    			cj=(cj*num)%10000;
            if(!flag)
    			sum=(sum+cj)%10000;
            ch=xg;
        }
        printf("%lld",sum);
        return 0;
    }
    
  • 相关阅读:
    CSS-16-margin值重叠问题
    CSS-15-定位
    CSS-14-浮动
    CSS-13-块级元素和行内元素
    CSS-12-盒子模型
    CSS-11-外边距
    CSS-10-内边距
    CSS-09-背景属性
    CSS-08-边框属性设置
    CSS-07-CSS文本设置
  • 原文地址:https://www.cnblogs.com/fusiwei/p/13867892.html
Copyright © 2011-2022 走看看