本次作业要求来自:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/2166

github远程仓库的地址:https://github.com/mingbiaoleung/FourOperation

第一部分:要求

1.作业需求:任何编程语言都可以,命令行程序接受一个数字输入,然后输出相应数目的四则运算题目和答案。例如输入数字是 30, 那就输出 30 道题目和答案。 运算式子必须至少有两个运算符,运算数字是在 100 之内的正整数,答案不能是负数。

2.拓展要求

1) 要求能出和真分数 (二分之一, 十二分之五,等)相关的练习题。

2) 并且要求能处理用户的输入,并判断对错,打分统计。 要求能处理用户输入的真分数, 如 1/2, 5/12 等。

初步拟定要实现的功能后,估计一下自己需要花多长时间。编程过程中记录自己实际用了多长时间。

然后和同学们比较一下各自程序的功能、实现方法的异同等等。

第二部分:设计

1.需求分析

   (1)随机产生 100 之内的正整数或者真分数的题目。
   (2)答案不能是负数。
   (3)题目数根据用户而定。
     (4)运算式子必须至少有两个运算符。
.    (5)判断用户输入值的对错,并给出用户的正确题目数和分数。

2.功能设计

1.根据用户要求的题目数,循环num次输出随机四则运算。

2.判断用户输入值是否正确,并给出正确题目数。

3.答案不能小于0,小于0就重新输出题目。

4.能出和真分数 (二分之一, 十二分之五,等)相关的练习题。

3.代码规范

  命名规范:使用匈牙利命名法

  程序风格:程序按照阶梯式编写,括号习惯使用其一个括号在语句后面,结尾括号另占一行

  注释规范:函数头的注释(“功能”,“返回值”),在一些关键的语句上面进行注释

第三部分:代码实现

总体设计:

◻随机产生100以内的正整数,运算符号以及正整数和运算符号的数量,通过调参可以调整生成正整数和运算符号的数量,四则运算乘除和加减优先级别:先乘除后加减,在计算函数中遍历运算符数组中乘除符号后进行优先计算,之后再对乘除计算之后的运算数进行相加减运算。

◻真分数设计:随机生成真分数,分子与分母大小范围在1-20随机生成,范围可以通过改变参数进行调整,分数约分后用对象进行存储。可以通过改变参数对分数运算数的数量(计算难度较大,这里使用生成两个运算数进行运算)。分数运算时,优先乘除后再相加减,会对最终计算结果进行约分到最简。

◻当随机产生的正整数运算题和真分数运算题计算结果为负数则递归重新生成运算题,直至结果是大于零时产生题目并打印在控制台上,用户输入答案,答案与结果匹配正确即统计正确题数,错误的输出打印正确结果,当全部运算题做完后输出统计结果以及分数。分数计算公式: 100 * (正确数 / 总题数)。

主要代码:

 // 生成运算公式并计算正确结果,将最终的存入List中
public void generateFormula() {
Random random = new Random();
int operationNum = random.nextInt(3) + 3; //运算数的个数
int operatorNum = operationNum - 1; //运算符的个数 List<String> newOperators;
List<Integer> newOperations;
int newAnswer;
//计算运算式答案
do {
List<String> operators = storeOpInList(operatorNum);
List<Integer> operations = operations(operationNum, operators);
newOperators = deepCopy(operators);
newOperations = deepCopy(operations);
newAnswer = generateCorrectAnswer(operators, operations);
} while (newAnswer < 0); StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < operationNum - 1; i++)
stringBuilder.append(newOperations.get(i) + " " + newOperators.get(i) + " ");
stringBuilder.append(newOperations.get(operationNum - 1) + " = ");
System.out.println(stringBuilder.toString());
operatorExpressionList.add(stringBuilder.toString());
correctAnswerList.add(String.valueOf(newAnswer));
}
/**
* @author: 梁铭标
* @Date:2018.10.10
* @Content:可序列化真分数对象
*/
public class Fraction implements Serializable {
private static final long serialVersionUID = -3245478690496182643L;
private int numerator; //分子
private int denominator; //分母 public Fraction(int numerator, int denominator) {
this.numerator = numerator;
this.denominator = denominator;
} public int getNumerator() {
return numerator;
} public int getDenominator() {
return denominator;
} public void setNumerator(int numerator) {
this.numerator = numerator;
} public void setDenominator(int denominator) {
this.denominator = denominator;
}
}

计算真分数运算式的正确结果

 // 计算真分数运算式的正确结果
public Fraction generateCorrectAnswer(List<String> operators, List<Fraction> operations) {
//遍历运算符容器,完成乘除运算
for (int i = 0; i < operators.size(); i++) {
String operator = operators.get(i);
if (operator.equals("*") || operator.equals("/")) {
operators.remove(i); //乘除符号将其从集合中移除
Fraction fractionLeft = operations.remove(i); //拿运算符左侧的数字
Fraction fractionRight = operations.remove(i); //拿运算符右侧的数字
if (operator.equals("*"))
operations.add(fractionMultiple(fractionLeft, fractionRight));
else
operations.add(fractionDivide(fractionLeft, fractionRight));
i--; //运算符容器的指针回到原来的位置,防止跳过下一个运算符
}
} //遍历运算符容器,完成加减运算,当运算符容器为空时,运算结束
while (!operators.isEmpty()) {
String operator = operators.remove(0);
Fraction fractionLeft = operations.remove(0);
Fraction fractionRight = operations.remove(0);
if (operator.equals("+"))
fractionLeft = fractionAdd(fractionLeft, fractionRight);
else
fractionLeft = fractionSubtract(fractionLeft, fractionRight);
operations.add(0, fractionLeft);
} //返回计算结果
return operations.get(0);
}

该作业的程序总引擎

/**
* @author: 梁铭标
* @Date:2018.10.10
* @Content:正整数和真分数总引擎
*/
public class ExecutionEengine {
public static void main(String[] args) {
SimpleFourOperation simpleFourOperation = new SimpleFourOperation();
simpleFourOperation.init();
FractionOperation fractionOperation = new FractionOperation();
Scanner scanner = new Scanner(System.in);
System.out.print("请输入生成四则运算题目的个数:");
int titleNum = handleUserInput(scanner); //随机生成正整数和分数的题目数量
Random random = new Random();
int simpleFourOperationNum = random.nextInt(titleNum) + 1;
int FractionOperationNum = titleNum - simpleFourOperationNum; //分别获取用户做对相应题目的正确数
int simpleFourOpTrueNum = simpleFourOperation.generateSimpleFourOpExp(simpleFourOperationNum, scanner);
int fractionOpTrueNum = fractionOperation.generateFractionOpExp(FractionOperationNum, scanner); //计算总分数
int trueNum = simpleFourOpTrueNum + fractionOpTrueNum;
int falseNum = titleNum - trueNum;
int score = 100 * trueNum / titleNum; System.out.println("恭喜你完成这次练习,题目总数:" + titleNum + ", 你做对了" + trueNum + "道题,"
+ "做错了" + falseNum + "道题, " + "总分数为" + score + ", 继续加油!");
} public static int handleUserInput(Scanner scanner) {
int titleNum;
do {
titleNum = scanner.nextInt();
if (titleNum > 0)
break;
else {
System.out.println("输入有误,不能输入非法字符以及小于0,请重新输入!");
System.out.println("请输入生成四则运算题目的个数:");
}
} while (!(titleNum > 0));
return titleNum;
}
}

运行结果:

第四部分:问题及解决方法

1.怎么解决先乘除后加减的问题?

先乘除后加减,在计算结果函数中遍历运算符数组中乘除符号后,在从存储运算数数组获取相对应的运算数进行优先计算,之后再对乘除计算之后的运算数进行相加减运算。

2.结果可以为负数,试了很多方法,最终找了一个好的方法?

定义一个在结果为负数和下一次循环的变量,用来控制题目数量,大于0就输出题目。

3.分数怎么约分?

将分子和分母的最小值的数值,从大到小去除分子和分母,如果能够同时被整除,则以此数值约分。

总结:

通过这次练习,明白了一个程序开发是一件不容易的事情,没有好的知识功底是无法创造出高质量高拓展的软件。天生我才必有用,千金散尽还复来,我会用这句话激励自己用功学习。

第五部分:个人软件过程耗时估计与统计表

PSP2.1 Personal Software Process Stages 预计hour 实际hour
Planning 计划 0.1 0.3
· Estimate 估计这个任务需要多少时间 5 9.0
Development 开发 0.3 6.0
· Analysis 需求分析 (包括学习新技术) 0.4 0.4
· Design Spec 生成设计文档 0.3 0.3
· Design Review 设计复审 0.2 0.3
· Coding Standard 代码规范 0.1 0.5
· Design 具体设计 0.3 0.3
· Coding 具体编码 2 2
· Code Review 代码复审 0.3 0.5
· Test 测试(自我测试,修改代码,提交修改) 0.3 1.0

Java小学四则运算的更多相关文章

  1. java实现自动生成小学四则运算——朱庭震,詹祺豪

    组员:朱庭震,詹祺豪 Github地址:https://github.com/ztz1998/second/tree/master 1题目:实现一个自动生成小学四则运算题目的命令行程序. 2说明: 自 ...

  2. 小学四则运算练习(JAVA编写)

    源码在Github的仓库主页链接地址:https://github.com/rucr9/rucr 看到这个题目,大概很多人会发出“切,这也太简单了吧!有必要小题大做?”的感叹!是的,仅仅作为一道数学运 ...

  3. 小学四则运算APP 最后阶段

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 这次发布的是我们APP的最终版本!图片背景有根据用户需求改变!还增加了草稿纸运算的画布功能! 运行结果如下: package com.ex ...

  4. 小学四则运算APP 第三阶段冲刺-第一天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第三次冲刺阶段时间:12.12~12.19 本次发布的是音乐播放功能,可以根据用户需求一边播放音乐一边做题,也拥有暂停播放音乐的功能,增强 ...

  5. 小学四则运算APP 第二阶段冲刺-第五天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第二次冲刺阶段时间:11.29~12.09 本次发布的是判断题代码,已经实现部分功能,,但是美中不足的是判断错误 panduanset.j ...

  6. 小学四则运算APP 第二次冲刺 第四天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第二次冲刺阶段时间:11.29~12.09 本次发布的是合并后的选择题功能界面的设置: ChoiceSet.java: package c ...

  7. 小学四则运算APP 第二阶段冲刺-第三天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第二次冲刺阶段时间:11.29~12.09 本次发布的是判断题的部分代码 panduanset.java import com.examp ...

  8. 小学四则运算APP 第二个冲刺 第一天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第二次冲刺阶段时间:11.29~12.09 本次发布的是已完成的功能二(选择题): ChoiceActivity.java: packag ...

  9. 小学四则运算APP 第一个冲刺 第八天

    团队成员:陈淑筠.杨家安.陈曦 团队选题:小学四则运算APP 第一次冲刺阶段时间:11.17~11.27 本次发布的是还未完成的功能二(选择题): ChoiceActivity.java: packa ...

随机推荐

  1. kafka源码导入idea/eclipse

    先进入源码工程:执行gradle idea或者gradle eclipse 之后再导入idea/eclipse

  2. c# 自定义验证登录(Authorize)

    我们的项目本来是用azure的auth认证,是用过程中发现登录速度太慢了,所以还是自己搞一个吧,没想到搞起来挺简单的,不是用一个专门的认证服务器哈,就是一个简单的工具类. 验证是否登录的类 /// & ...

  3. Bootstrap4后台导航栏制作

    <!Doctype html> <html lang="zh-cn"> <head> <!-- Required meta tags -- ...

  4. ASP.NET Core部署IIS问题总结

    部署准备工作 1.服务器开启添加IIS相关功能 1.1. 点击windows搜索到   “启用或关闭windows功能” 1.2 选择添加IIS的部分功能, 如下图所示 2.进入IIS,添加已经发布的 ...

  5. C++贪心算法实现活动安排问题

    问题描述: 设有n个活动的集合E={1,2,…,n},其中,每个活动都要求使用同一资源,而在同一时间内只有一个活动能使用这一资源.每个活动i都有一个要求使用该资源的起始时间si和一个结束时间fi,且s ...

  6. Java自学-集合框架 与数组的区别

    Java集合框架与数组的区别 示例 1 : 使用数组的局限性 如果要存放多个对象,可以使用数组,但是数组有局限性 比如 声明长度是10的数组 不用的数组就浪费了 超过10的个数,又放不下 //Test ...

  7. Extjs 树菜单的自动展开数据的请求

    今天在做extjs开发的时候,在树菜单上遇到了一个坑,也许是我刚接触extjs 不熟的缘故 问题描述:后台设置的树自动展开,但是在前端总是只显示一条数据,但是数据确实都请求到了. 经过几个小时不屑的努 ...

  8. 12个有趣的C语言问答

    转自:http://www.admin10000.com/document/913.html 1,gets() 方法 Q:以下代码有个被隐藏住的问题,你能找到它吗? 1 2 3 4 5 6 7 8 9 ...

  9. 易语言 MD5生成

    下载MD5脚本 https://download.csdn.net/download/zhangxuechao_/10573121 添加脚本组件 定义常量 生成MD5

  10. 高性能TcpServer(Java) - Netty

    源码下载 -> 提取码  QQ:505645074 Netty 是一个高性能.异步事件驱动的 NIO 框架,它提供了对 TCP.UDP 和文件传输的支持,作为一个异步 NIO 框架,Netty ...