相关过程截图

  • 截图为我负责的部分关于计算的测试

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

关键代码解释

  • 根据代码中的部分解释,这部分代码实现了结果的整数和分数的输出,如果算出的结果为一个真分数,就输出真分数的形式,如果结果为整数,就输出整数形式。

    private RationalNumber becom(String str) {
    StringTokenizer tokenizer = new StringTokenizer(str, "/"); //以/为分隔符把每个分式拆开
    int zi = Integer.parseInt(tokenizer.nextToken());
    int mu;
    if (tokenizer.hasMoreTokens()) //如果存在分式就输出
    mu = Integer.parseInt(tokenizer.nextToken());
    else
    mu = 1; //如果没有分式就把分母变为1 return new RationalNumber(zi, mu);
    }
  • 这部分判断正误,并统计正确错误的题目数。

    for (int y = 0; y < number.length; y++) {
    if (number[y].equals(rightanswer[y])) { // 比较正确答案与用户的答案
    System.out.println("正确!");
    right++; // 正确题数加一
    } else {
    System.out.println("错误!");
    wrong++; // 错误题数加一
    System.out.println("正确答案是" + rightanswer[y]);
    }
    }

遇到的困难及解决方法

  • 问题一:将后缀表达式用空格作为分隔符分开存入栈中后,定义为String型还是char型都是错误的

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

  • 问题一解决:由于之后要调用RationalNumber方法,其参数为int型,这样就产生了矛盾,之后把a1,a2都定义为Object型的就可以避免这一矛盾。

  • 问题二:不知道如何使用StringTokenizer方法

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP
  • 问题二解决:在查看了API文档之后,尝试着使用了一下,但错误很多,StringTokenizer处显示红色,然后我便声明了一个构造方法,并实例化,结果仍是错误的,最后发现可能是没有导入包的原因,便把构造方法删除,直接加包名java.util.StringTokenizer。import导入包StringTokenizer就是可以直接使用里面的方法,所以,就已经有了构造方法,可以直接实例化创建对象。参考java导入包
![](https://images2018.cnblogs.com/blog/1333122/201805/1333122-20180508205959986-1134941156.jpg)
  • 问题三:在计算时,最开始想要通过判断一个字符是否是数字来决定什么时候进行计算。

  • 问题三解决:在网上查找之后找到了Character.isDigit(char)方法,Java中怎样判断一个字符串是否是数字,但最后选择直接用equals方法把四个运算符找出来,没有用这个方法。

  • 问题四:运行时显示18行有错误。

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

  • 问题四解决:在单步调试之后,是这里的循环出了问题,第二遍循环就结束了,感觉是push进character栈中的nextToken是在if判断中的nextToken的下一个,并不是同一个运算符,所以定义一个xx来代替就避免了,再次运行之后这里没有错误。

    2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

项目中自己负责的部分

我负责后缀表达式的计算并判断用户计算的正误,得到正确率。并且打算做文件的部分。代码如下:

  • 计算后缀表达式

    package test;
    
    import test.RationalNumber;
    import java.util.Stack ;
    import java.util.StringTokenizer; public class Judge { Stack<String> calculate; public Judge() {
    calculate = new Stack<>();
    } public String answer(String Stringwyh) {
    //以空格为分隔符分开每个分数和运算符
    StringTokenizer NUM = new StringTokenizer(Stringwyh, " "); while (NUM.hasMoreTokens()) {
    String xx = NUM.nextToken();//xx表示一个分数或字符 if (xx.equals("+")) {
    String a = calculate.pop();
    String b = calculate.pop(); String re = becom(a).add(becom(b)).toString(); calculate.push(re);
    }//如果是运算符则进行计算
    else if (xx.equals("-")) {
    String a = calculate.pop();
    String b = calculate.pop(); String re = becom(a).subtract(becom(b)).toString(); calculate.push(re);
    }//如果是运算符则进行计算
    else if (xx.equals("*")) {
    String a = calculate.pop();
    String b = calculate.pop(); String re = becom(a).multiply(becom(b)).toString(); calculate.push(re);
    }//如果是运算符则进行计算
    else if (xx.equals("÷")) {
    String a = calculate.pop();
    String b = calculate.pop(); String re = becom(a).divide(becom(b)).toString(); calculate.push(re);
    }//如果是运算符则进行计算
    else
    calculate.push(xx);//如果是将分数则存入calculate栈中
    }
    return calculate.pop();
    } private RationalNumber becom(String str) {
    StringTokenizer tokenizer = new StringTokenizer(str, "/");
    int zi = Integer.parseInt(tokenizer.nextToken());
    int mu;
    if (tokenizer.hasMoreTokens())
    mu = Integer.parseInt(tokenizer.nextToken());
    else
    mu = 1; return new RationalNumber(zi, mu);
    } }
  • 判断正误

    package test;
    
    import test.Judge;
    import test.NifixExpression; import java.util.Scanner; public class Test1 {
    public static void main(String[] args) { int right = 0;
    int wrong = 0;
    double rate;
    Scanner scan = new Scanner(System.in);
    //生成题目
    System.out.print("整数运算为1,分式运算为2: ");
    int a = scan.nextInt();
    System.out.print("请输入您要做的题目等级: ");
    int b = scan.nextInt();
    System.out.print("请输出该等级的题目量: ");
    int c = scan.nextInt(); String[] number = new String[c];//数组number用来存放用户输入的答案
    String rightanswer[] = new String[c];//数组rightanswer用来存放正确答案
    for (int d = 1; d <= c; d++) {
    NifixExpression num = new NifixExpression();
    SuffixExpression num1 = new SuffixExpression();
    Judge num2 = new Judge();
    System.out.print("问题" + d + ": " + num.Level(b, a) + " " );
    int e = scan.nextInt();
    number[d - 1] = Integer.toString(e);
    rightanswer[d - 1] = num2.answer(num1.SuffixExpression(num.Level(b,a)));
    System.out.println();
    System.out.println(); //rightanswer[d - 1] = num1.answer(); for (int y = 0; y < number.length; y++) {
    if (number[y].equals(rightanswer[y])) {
    System.out.println("正确!");
    right++;
    } else {
    System.out.println("错误!");
    wrong++;
    System.out.println("正确答案是" + rightanswer[y]);
    } } rate = (double) right / c; System.out.println("正确率为" + rate); }
    }
    }

个人贡献度划分

我们组每个人的任务都差不多,少了那部分都不行,都很重要就每人33.3%吧。

对结对的小伙伴做出评价给出小伙伴博客链接(重点指出需要改进的地方)

  • 谭鑫谭鑫很有想法,并且乐于攻坚,尝试用不同的方法,非常卖力。
  • 王禹涵王禹涵很有耐心,并且很沉稳,熬夜编写,很认真。

码云链接

小组结对编程照片

2017-2018-2 20172314 『Java程序设计』课程 结对编程练习_四则运算-LMLPHP

参考

05-12 18:11