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 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器