[NOIP2013]表达式求值

1.题目

题目链接

题号:NC16539
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld
题目描述
给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。

输入描述:

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

输出描述:

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

示例1
输入
1+1*3+4
输出
8
说明
计算的结果为8,直接输出8。

示例2
输入
1+1234567890*1
输出
7891
说明
计算的结果为1234567891,输出后4位,即7891。

示例3
输入
1+1000000003*1
输出
4
说明
计算的结果为1000000004,输出后4位,即4。

备注:
对于30%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100;
对于80%的数据,0≤表达式中加法运算符和乘法运算符的总数≤1000;
对于100%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100000。

2.分析

3.代码

方法1:将数字,符号分别存储,并将计算的结果再存一个数组

#include <stdio.h>

int main()
{
    long long Numbers[100005],Statistic[100005],Sum=0;
    char Ch[100005];
    int i=0,j=0,k=0;
    while(scanf("%lld",&Numbers[i])!=EOF)
    {
        scanf("%c",&Ch[i]);
        i++;
    }
    
    for(j=0;j<i;j++)
    {
        
        long long temp=1;
        if(Ch[j]=='*')
        {
            while(Ch[j]=='*'&&j<i)
            {
                temp=(temp*Numbers[j])%10000;  //防止溢出
                j++;
            }
        Statistic[k++]=(temp*Numbers[j])%10000;  //存储
        }
        else
            Statistic[k++]=Numbers[j];
    }
    
    for(i=0;i<k;i++)
        Sum+=Statistic[i];
    printf("%lld",Sum%10000);
    return 0;
}

在这里插入图片描述

方法2:依次字符、数字检验(***)

#include <stdio.h>
int main()
{
    char Ch;
    int A,B,C;
    int Sum=0;
    scanf("%d",&A);
    
    while(scanf("%c%d",&C,&B)!=EOF)
    {
        if(C=='+')
        {
            Sum=(Sum+A)%10000;
            A=B;       //更新A
        }
        if(C=='*')
        {
            int t=(A*B)%10000;   //计算乘积
            A=t;
        }
    }
    Sum=(Sum+A)%10000;
    printf("%d",Sum);
    return 0;
}

在这里插入图片描述

4.总结

算法思路很重要

5.更新日志

2022.3.23 整理

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值