[NOIP2013]表达式求值

  • 1.题目
  • 2.分析
  • 3.代码
    • 方法1:将数字,符号分别存储,并将计算的结果再存一个数组
    • 方法2:依次字符、数字检验(***)
  • 4.总结
  • 5.更新日志

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;  //存储}elseStatistic[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 整理

[NOIP2013]表达式求值相关推荐

  1. NOIP2013普及组 T2 表达式求值

    OJ地址:洛谷P1981 CODEVS 3292 正常写法是用栈 1 #include<iostream> 2 #include<algorithm> 3 #include&l ...

  2. 信息学奥赛一本通 1962:【13NOIP普及组】表达式求值 | 洛谷 P1981 [NOIP2013 普及组] 表达式求值

    [题目链接] ybt 1962:[13NOIP普及组]表达式求值 洛谷 P1981 [NOIP2013 普及组] 表达式求值 [题目考点] 栈 中缀表达式转后缀表达式,后缀表达式求值 中缀表达式求值 ...

  3. 经典笔试上机考题-表达式求值

    相信参加过笔试面试同学应当见到过表达式求值这道题,下面列举的一道经典的考题,本文将同大家一起细细探讨一下表达式求值这一类问题的求法,希望抛砖引玉,其中有不妥的地方也请大家多多批评指正. /* 功能:四 ...

  4. 栈 -- 顺序栈、链式栈的实现 及其应用(函数栈,表达式求值,括号匹配)

    文章目录 实现 顺序栈实现 链式栈实现 应用 函数栈 的应用 表达式求值中 的应用 括号匹配中 的应用 我们使用浏览器的时候经常会用到前进.后退功能. 依次访问完一串页面 a – b – c之后点击后 ...

  5. 【Java】LeetCode 150. 逆波兰表达式求值 (后缀表达式)

    题目: 根据 逆波兰表示法,求表达式的值. 有效的算符包括 +.-.*./ .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话 ...

  6. C语言----表达式求值之隐式类型转换

    前言: 表达式求值的顺序一部分是由操作符的优先级和结合性决定. 同样,有些表达式的操作数在求值的过程中可能需要转换为其他类型,称为隐式类型转换,下面给出隐式类型转换的详细讲解,希望对大家有所帮助~ 隐 ...

  7. [数据结构]表达式求值

    一.问题描述 表达式求值是数学中的一个基本问题,也是程序设计中的一个简单问题.我们所涉及的表达式中包含数字和符号,本实验中处理的符号包括'+'.'-'.'*'.'/'.'('和')',要求按照我们所习 ...

  8. c语言作业算术表达式求值,算术表达式求值演示(C语言版)

    //头文件预处理命令 #include #include //----------函数结果状态代码----------------- #define TRUE 1 #define FALSE 0 #d ...

  9. 严蔚敏《数据结构》C语言版 第三章 算法3.4 表达式求值

    这个我是看到华为今年招聘的机试题的第三题. 输入一串算术表达式的字符串,把它的结果算出来. 1 //表达式求值(输入.输出和中间结果均只能是0-9)运算符仅限+-*/. 2 #include < ...

  10. 函数嵌套 lisp表达式求值

    问题 D: lisp表达式求值 时间限制: 1 Sec  内存限制: 128 MB 提交: 105  解决: 43 [提交][状态][讨论版] 题目描述 lisp是一种非常古老的计算机语言,是由约翰· ...

最新文章

  1. python3运行报错:TypeError: Object of type 'type' is not JSON serializable解决方法
  2. kalilinux安装qt_Kali Linux安装搜狗输入法(只需5步)
  3. 汇编语言-016(SCASB 、STOSB 、LODSD 、数组中的取值、二维数组操作、冒泡排序和二分查找、CMPSW )
  4. linux 目录结构+常用命令+压缩命令+vim使用+及一些基础知识(非常好)
  5. Google Developers可以访问了?
  6. android 百度地图大头针,百度地图(大头针)
  7. spring-security3 配置和使用
  8. NOIP经典基础模板总结
  9. ISAKMP包数据属性格式
  10. 《Android框架揭秘》——2.2节搭建Android平台编译环境
  11. 自定义httpSession
  12. 电脑罗盘时钟html怎么设置成桌面,抖音时钟屏保怎么设置 罗盘时钟屏保设置方法...
  13. 测试cpu温度软件mac,mac电脑怎么查看cpu温度和风扇转速的详细步骤
  14. 网易版服务器我的世界装模组的文件包在哪里,网易我的世界怎么加mod【给网易我的世界里装mod】...
  15. matlab中矩阵行列式,MATLAB矩阵行列式
  16. 如何优化关键词搜索排名(提升关键词排名的方法)
  17. CentOS 安装显卡驱动
  18. 写论文时如何翻译外文文献?
  19. 国外服务器被攻击以及应对方法
  20. 箱包卖家注意了!《淘宝网箱包行业标准》出炉 !

热门文章

  1. STM32CubeIDE 下载及安装教程
  2. java项目怎么启动_github上的java项目怎么运行(面向小白)
  3. 循序渐进PostgreSQL: 学习pqxx C++ API访问
  4. Spring揭秘-笔记
  5. 专业的售后服务管理系统
  6. 改进型MUSIC算法(python)
  7. abaqus2017安装后启动cae报错_Abaqus2017安装全过程
  8. ctf是用Windows还是Linux,CTF中zip总结
  9. B站上这些Python和数据分析视频真香!
  10. 数据分析工作到底在做什么