结对编程项目-四则运算

写在前面

  • 我的结对伙伴王旌含
  • 关于四则运算的结对编程项目我和结对伙伴在不久前就有所涉及,但现在看来简直是菜鸡互啄,随着学习的深入和知识的不断补充,编程项目也会越做越好。
  • 在编程中我的角色更倾向于领航员的角色,但在某些代码编写中我也化身为副驾驶,协作,检查,护航。

需求分析

  • 我想要干什么
  • 自动生成小学四则运算题目(加、减、乘、除)
  • 支持整数,支持多运算符,支持真分数
  • 统计正确率
  • 我有哪些知识
  • 了解了中缀和后缀表达式
  • 了解栈的使用
  • 编写过分数的四则运算程序
  • 我还需补充什么
  • 熟悉调度场算法
  • 支持真分数

设计思路

  • 设计三个难度,对应运算符的多少以及是否加入括号
  • 设计两种类,一种用来生成题目,一种用来计算题目
  • 计算:现将中缀表达式转换为后缀,在进行计算

阶段成果

  • 调度场算法
    在邹老师的调度场算法中提到如果在上面的过程中不执行计算,直接将数字和出栈的符号依次输出,我们就会得到后缀表达式

  • 通过阅读了解到要想将中缀改为后缀有两个关键问题

  • 如何去除括号
  • 如何处理运算符的优先级
  • 我的解决思路
    //解决去除括号问题
    //如果读入的操作符为非")"且优先级比栈顶元素的优先级高或一样,则将操作符压入栈
    if (Number(Opera.peek()) < Number(token) && !token.equals(")")) {...}
    //如果读入的操作符是")",则弹出从栈顶开始第一个"("及其之前的所有操作符
    else if (token.equals(")")) {
                        while (!Opera.peek().equals("(")) {
                            String operator = Opera.pop();
                            Methoder.append(operator);
                            stack.push(operator);
                        }
                        Opera.pop();
                    }
    //解决运算符优先级的问题
    private static int Number(String token){
        switch (token) {
            case "+":return 1;
            case "-":return 1;
            case "*":return 2;
            case "/":return 2;
            case "(":return 3;
            case ")":return 3;
            default :return 0;
        }
    }
  • 编写好将题目写入文件的基础类(王旌含)

  • 编写好产生初级题目的类(王旌含)

  • 编写好单一运算符的分数计算基础类(王旌含)

  • 以上就是一些阶段成果,还有正在解决的问题

  • 产生多运算符题目时如何将括号插入有效位置
  • 未能解决分数的多运算符计算

成果展示

码云项目

posted @ 2017-05-14 19:27  Wb同学在此  阅读(178)  评论(8编辑  收藏  举报