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

小组成员

  • 20172326康皓越
  • 20172313余坤澎
  • 20172332于欣月

小组编程照片

设计思路

  • 设计一个生成符号类

    • 包括加减乘除和括号
  • 设计一个数类
    • 包括整数和分数
  • 设计一个表达式类
    • 需要调用符号类和数类。
  • 设计一个运算类
    • 对生成的表达式进行处理,
    • 然后使之转换成后缀表达式,
    • 进而计算出后缀表达式的值。
    • 添加判断对错和正确率的方法。
  • 在后续的扩展中设计一个文本处理类
    • 实现将生成题目写入文件中
    • 从文件中读取题目并计算和判题。

重要代码及代码解释

  • 1.数类中的

      private int gcd(int num1,int num2)
    {
    while (num1 !=num2) {
    if (num1 > num2)
    num1 = num1 - num2;
    else
    num2 = num2 - num1;
    } return num1;
    }
    private void reduce()
    {
    if (numerator !=0)
    {
    int common = gcd(Math.abs(numerator),denominator); numerator = numerator/common;
    denominator = denominator/common;
    }
    }

这两个方法使我们生成的分数进行了约分。

  • 2.生成表达式类中

              //先做出括号并且做出括号里的内容
    String kuohao = "";
    int ge = a.nextInt(2) + 2;
    Elements c = new Elements();
    c.khq();
    kuohao += c;
    for (int i = 0; i <= ge; i++) {
    Num b = new Num();
    b.getNum();
    kuohao += b.toString();
    int el = a.nextInt(2);
    if (el == 0) {
    c.add();
    kuohao += c;
    } else {
    c.sub();
    kuohao += c;
    }
    }
    Num e = new Num();
    e.getNum();
    c.khh();
    kuohao += e.toString() + c;

先把括号以及括号内的内容创建出来,然后再用随机数去判断括号发在表达式中的位置。

  • 3.生成表达式类中的

              //分别判断是否有无加减或乘除,并进行相应的随机添加加减或者乘除法,以保证达到混合运算的目的。
    Elements p = new Elements();
    Num w = new Num();
    w.getNum();
    if (count1 != 0 && count2 != 0)
    result = result;
    else if (count1 == 0) {
    Random m = new Random();
    int n = m.nextInt(2);
    //选择加还是减
    if (n == 0) {
    p.add();
    result += p + w.toString();
    } else {
    p.sub();
    result += p + w.toString();
    }
    } else {
    Random m = new Random();
    int n = m.nextInt(2);
    //选择乘还是除
    if (n == 0) {
    p.mul();
    result += p + w.toString();
    } else {
    p.div();
    result += p + w.toString();
    }
    }

因为等级三中无括号的是混合运算,加减其中之一和乘除其中之一必须有,为了防止表达式生成的不符合要求,所以做出了以上代码,判断是否存在加减或乘除,不存在就加上相应所缺的。

  • 4.生成表达式类中的等级三有括号的时候

                   //分别判断是否有乘除,并进行相应的乘除法添加,以保证达到混合运算的目的。
    Elements p = new Elements();
    Num w = new Num();
    w.getNum();
    if (count2 == 0) {
    Random m = new Random();
    int n = m.nextInt(2);
    if (n == 0) {
    p.mul();
    result += p + w.toString();
    } else {
    p.div();
    result += p + w.toString();
    }
    } else
    result = result;
    }

因为括号中就包含了加减,所以只需要判断乘除存不存在的情况

  • 5.计算类中判断正确的方法中

      if (result2 - doCal(list) < 0.001 && result2 - doCal(list) > -0.001)

因为IEEE754浮点数的原因,所以可能正确答案与用户所属的正确答案有所差异,所以规定了精确度内,就认为相等。

项目链接

码云地址

小组结对博客

代码贡献度

余坤澎 于欣月 康皓越
个人贡献度 30% 40% 30%

遇到的困难及解决方法

  • 困难1:刚开始创建的数类没有约分的方法,所以出现的数了可以约分的数。
  • 困难1解决方案1:书中例题之前有一个分数的类,其中就包含了约分的方法。
  • 困难2:刚开始我们是一个数必定带一个符号,但是发现括号不好加。
  • 困难2解决方案:把数和符号分开,并且先做出括号内容,再把括号加入表达式中。
  • 困难3:计算类中乘除类得出的结果不正确。
  • 困难3解决方案:暂时还没解决该问题,还需一定时间。
  • 困难4:文件处理,如今只能写入文件,还差从文件中读入。
  • 困难4解决方案:暂时还没解决该问题,需要看看视频研究一下。

文件扩展(加分项)

  • 现只能写入文件,下周改进。

20172332『Java程序设计』课程结对编程练习_四则运算第二周阶段总结的更多相关文章

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

    20172313『Java程序设计』课程结对编程练习_四则运算第二周阶段总结 结对伙伴 20172326康皓越 博客地址(http://www.cnblogs.com/326477465-a/p/90 ...

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

    20172326『Java程序设计』课程结对编程练习_四则运算第二周阶段总结 小组成员 20172313 余坤澎 20172332 于欣月 20172326 康皓越 小组编程照片 设计思路 通过一个E ...

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

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

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

    20172321『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号 :20172324 姓名 :曾程 伙伴第一周博客地址: 对结对伙伴的评价:一个很优秀的同学,在这次项目中 ...

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

    20172325『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号:20172306 姓名:刘辰 结对伙伴博客链接 刘辰同学对编程的积极程度很高,并且在编程能力上很不错,有 ...

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

    一.结对对象 姓名:周亚杰 学号:20172302 担任角色:驾驶员(周亚杰) 伙伴第二周博客地址 二.本周内容 (一)继续编写上周未完成代码 1.本周继续编写代码,使代码支持分数类计算 2.相关过程 ...

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

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

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

    一.结对对象 姓名:侯泽洋 学号:20172308 担任角色:驾驶员(侯泽洋) 伙伴第二周博客地址 二.本周内容 (一)继续编写上周未完成代码 1.本周继续编写代码,使代码支持分数类计算 2.相关过程 ...

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

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

随机推荐

  1. Redis 持久化深入--机制、可靠性及比较

    本文是对 antirez 博客中 Redis persistence demystified 的翻译和总结.主要从Redis的持久化机制,提供何种程度的可靠性以及与其他数据库的比较三个方面进行讨论. ...

  2. Spark Streaming 进阶与案例实战

    Spark Streaming 进阶与案例实战 1.带状态的算子: UpdateStateByKey 2.实战:计算到目前位置累积出现的单词个数写入到MySql中 1.create table CRE ...

  3. Docker CPU Usage

    背景 当一台机器上跑有多个 Docker Container 的时候,我们需要知道,哪些容器占用了多少资源.采集这些指标,来让我们可以更加好的分配资源给每个 Container. 获取容器CPU使用率 ...

  4. 基于R实现k-means法与k-medoids法

    k-means法与k-medoids法都是基于距离判别的聚类算法.本文将使用iris数据集,在R语言中实现k-means算法与k-medoids算法. k-means聚类 首先删去iris中的Spec ...

  5. SDR软件无线电知识要点(三)EVM

    SDR软件无线电知识要点(三)EVM 信号质量如何评估 Noise Figure (NF) or sensitivity and Error Vector Magnitude (EVM) provid ...

  6. 20155211 2016-2017-2 《Java程序设计》第十周学习总结

    20155211 2016-2017-2 <Java程序设计>第十周学习总结 教材学习内容总结 网络编程的实质就是两个(或多个)设备(例如计算机)之间的数据传输 在实际传输数据以前需要将域 ...

  7. 20155233 2006-2007-2 《Java程序设计》第2周学习总结

    20155233 2006-2007-2 <Java程序设计>第2周学习总结 教材学习内容总结 本章主要学习Java的基础语法,这些语法在C语言的学习中基本上都涉及到过,基本上,Java可 ...

  8. BZOJ1096_仓库建设_KEY

    题目传送门 一道斜率优化的题目,加深了印象. 设sum[i]=∑p[i],S[i]=∑p[i]*x[i]. 暴力方程加前缀和优化: f[i]=min(f[j]+c[i]+(sum[i]-sum[j]) ...

  9. OpenCV中对Mat里面depth,dims,channels,step,data,elemSize和数据地址计算的理解

    原文:OpenCV中对Mat里面depth,dims,channels,step,data,elemSize和数据地址计算的理解 Title : cv::Mat depth/dims/channels ...

  10. 使用SCSS扩展Bootstrap4

    摘要 因为打算写一个小网站,而个人时间又不是那么充裕,所以没有选择前后端分离的架构. 对于非前后端分离应用来说,Bootstrap应该是目前的最佳前端框架之一了. 而Bootstrap4,是Boots ...