qq_35235949 2016-06-07 01:20 采纳率: 0%
浏览 1343

谁能教教我怎么编写这个程序

出题给小学生做,每次考试的题数可以设定,随机产生n个题目,将题目及标准答案写入文件中;题目涉及加减乘除,带括弧的混合运算;根据答题情况给出分数;将学生的学号,每道题的答案,分数也写入文件中,即每个学生的考试情况放在一个文件中保存。
一个算式的求值:求一个可能包含加、减、乘、除运算的中缀表达式的值。在计算机中,我们常用栈来解决这一问题。首先将中缀表达式转换到后缀表达式,然后对后缀表达式求值。加、减、乘、除分别用+,-,*, /,来表示。表达式可以有圆括号()。每个表达式中,圆括号、运算符和运算数相互之间都用空格分隔,运算数是整数,考虑除数为0的情况,除法的商向下取整。

[测试数据]
2 * 5 + 6 * ( 7 - 8 ) + 6 输出结果为10

[实现提示]
(1)在程序中会用到两类栈:操作数栈和运算符栈,分别为整型数据和字符型数据,设置运算符栈和操作数栈辅助分析算符优先关系;
(2) 在读入字符序列时,完成运算符和操作数的处理,以及相应运算;
(3) 算符之间的优先关系可参考数据结构教材 。

  • 写回答

1条回答 默认 最新

  • lbcab 2016-06-07 01:32
    关注
    1. 先将中缀表达式转换成后缀表达式
      使用辅助栈, 从左只有扫描中缀表达式
      (1)如果遇到数字,直接放到后缀表达式尾;
      (2)如果遇到遇到运算符
      a:若此时站空,则直接入栈;
      b:循环:若栈st不空且栈顶运算符的优先级大于等于当前的运算符,则栈顶运算符出栈,置于后缀表达式尾;
      c:若栈st不空且栈顶运算符的优先级小于当前的运算符,则将此运算符直接入栈;
      反复执行1,2,知道整个中缀表达式扫描完毕,若此时栈st不空,则将栈顶的运算符依次出栈,依次置于后缀表达式尾。

    2. 使用后缀表达式求值
      从左到右遍历后缀表达式, 如果是数字,压栈, 如果是运算符, 将栈顶两元素出栈计算, 将结果压栈, 依次类推, 最后栈中只有一个值, 即为结果.

    评论

报告相同问题?

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题