相关过程截图

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

关键代码解释

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

    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型都是错误的



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

Object意思就是参数是可变的,意思就是说,你在调用这个方法的时候你可以给他传一个String类型的参数,也可以给他传一个Int类型的参数,或者多个不同类型的参数,很灵活的。

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

  • 问题二解决:在查看了API文档之后,尝试着使用了一下,但错误很多,StringTokenizer处显示红色,然后我便声明了一个构造方法,并实例化,结果仍是错误的,最后发现可能是没有导入包的原因,便把构造方法删除,直接加包名java.util.StringTokenizer。import导入包StringTokenizer就是可以直接使用里面的方法,所以,就已经有了构造方法,可以直接实例化创建对象。参考java导入包

在Java代码中导入包,与其说为了使用里面的方法,不如按照面向对象语言的特点,说成为了使用里面的类,因为Java作为典型的面向对象语言,他的程序是以数据作为基础,以类的形式组织的,类主要包括:你自己的写的类和你的类中需要用到的现有的类,这些现有的类基本上都是以package包的形式存在的,你只有导入了这个类所在的包,才能使用这个类。

![](https://images2018.cnblogs.com/blog/1333122/201805/1333122-20180508205959986-1134941156.jpg)
  • 问题三:在计算时,最开始想要通过判断一个字符是否是数字来决定什么时候进行计算。

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

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

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

项目中自己负责的部分

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

  • 计算后缀表达式

    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程序设计』课程 结对编程练习_四则运算的更多相关文章

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

    结对编程的好丽友 - 20172323 王禹涵:中缀转后缀 - 20172314 方艺雯:后缀表达式的计算 - 20172305 谭鑫:中缀表达式的输出 需求分析 能随机生成由使用者确定的任意多道四则 ...

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

    2017-2018-2 165X 『Java程序设计』课程 结对编程练习_四则运算 经过第一阶段的学习,同学们已经熟悉了这门语言基本的用法.在一次又一次对着电脑编写并提交代码,进行练习的时候,有没有觉 ...

  3. 2017-2018-2 20172310『Java程序设计』课程 结对编程练习_四则运算_第二周

    2017-2018-2 20172310『Java程序设计』课程 结对编程练习_四则运算_第二周 博客要求 组内同学需各自发表博客 博客中需包含以下内容: 相关过程截图 关键代码解释 遇到的困难及解决 ...

  4. 2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算_第三周

    2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算 组队成员: 仇夏 学号: 20172310 博客地址: @王志伟 四则运算第一周博客 @仇夏四则运算第一周博客 ...

  5. 2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算——第一周

    2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算 组队成员: 仇夏 学号: 20172310 博客地址:点击这里 1. 需求分析: 可生成题目: - 输入要想生成 ...

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

    2017-2018-2 20165225『Java程序设计』课程 结对编程练习_四则运算 需求分析: 支持整数,可进行多运算符运算,有优先级. 设计思路: 在有括号的情况下,先计算得出括号中的结果,如 ...

  7. 20172325『Java程序设计』课程 结对编程练习_四则运算第三周阶段总结

    20172325『Java程序设计』课程 结对编程练习_四则运算第三周阶段总结 结对伙伴 学号:20172306 姓名:刘辰 在这次项目的完成过程中刘辰同学付出了很多,在代码的实践上完成的很出色,在技 ...

  8. 20172311『Java程序设计』课程 结对编程练习_四则运算第一周阶段总结

    20172311『Java程序设计』课程 结对编程练习_四则运算第一周阶段总结 结对伙伴 学号 :20172307 姓名 :黄宇瑭 伙伴第一周博客地址: http://www.cnblogs.com/ ...

  9. 20172311『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结

    20172311『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号 :20172307 姓名 :黄宇瑭 伙伴第一周博客地址 对结对伙伴的评价:黄宇瑭同学的优势在于能够想出一 ...

随机推荐

  1. JavaScript深入之参数按值传递

    在<JavaScript高级程序设计>第三版 4.1.3,讲到传递参数: ECMAscript中所有函数的参数都是按值传递 按值传递 也就是,把函数外部的值复制给函数内部的参数,就和把值从 ...

  2. 关于mysql 删除数据后(.MYD,MYI)物理空间未释放

    关于mysql 删除数据后物理空间未释放 OPTIMIZE TABLE 当您的库中删除了大量的数据后,您可能会发现数据文件尺寸并没有减小.这是因为删除操作后在数据文件中留下碎片所致.OPTIMIZE ...

  3. 【AD】自己画板的备忘

    快捷键: [Ctrl + M ]计算出两点之间的距离,画电路板时会用到 [Ctrl + Q ]在设定X.Y..等等的地方,快捷键可以公英制快速切换 [shift + 空格键 ]在布线的同时,此快捷键可 ...

  4. 通过burpsuite替换cookie登录后台

    通过burpsuite可以比较方便的替换http头部的cookie.useragent等字段,在获取到用户的cookie后实现登录.具体使用方法如下: 如替换cookie,可以写正则表达式^Cooki ...

  5. PAT (Basic Level) Practice 1008 数组元素循环右移问题

    个人练习 一个数组A中存有N(>)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥)个位置,即将A中的数据由(A​0​​A​1​​⋯A​N−1​​)变换为(A​N−M​​⋯A​N ...

  6. 立个Flag (20180617-20181231)

    入行7年,今年年初正式接触Java,前面6年一直在做C++相关的工作,去年年中跳槽,语言从C++转向了C#,半年之后又转向了Java. 虽说语言有相似性,但每种语言都有自己独有的知识体系,想要游刃有余 ...

  7. shell之lvm

    #!/bin/bash #this script for LVM echo "Initial a disk..."  echo -e "\033[31mWarning: ...

  8. Codeforces Round #460 (Div. 2) 前三题

    Problem A:题目传送门 题目大意:给你N家店,每家店有不同的价格卖苹果,ai元bi斤,那么这家的苹果就是ai/bi元一斤,你要买M斤,问最少花多少元. 题解:贪心,找最小的ai/bi. #in ...

  9. 全球订单最多的成都优步推出"南北通勤线"业务

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  10. (转)Gmail,你必须了解的12个邮件编码问题

    转载地址:http://www.maildesign.cn/archives/1537 1.Gmail 不支持style=” display:none”2.Gmail不支持内嵌式CSS样式3.Gmai ...