隔壁村小学的小朋友都羡慕哭了2.0版


一、预估与实际

PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)
Planning 计划 15 20
• Estimate • 估计这个任务需要多少时间 800 1000
Development 开发 600 600
• Analysis • 需求分析 (包括学习新技术) 30 60
• Design Spec • 生成设计文档 20 30
• Design Review • 设计复审 10 30
• Coding Standard • 代码规范 (为目前的开发制定合适的规范) 10 10
• Design • 具体设计 30 40
• Coding • 具体编码 400 500
• Code Review • 代码复审 20 15
• Test • 测试(自我测试,修改代码,提交修改) 60 45
Reporting 报告 60 60
• Test Repor • 测试报告 30 30
• Size Measurement • 计算工作量 20 15
• Postmortem & Process Improvement Plan • 事后总结, 并提出过程改进计划 20 30
合计 1000

二、需求分析

我通过网上查阅和询问担任担任小学老师的姑姑了解到,小学三年级数学四则混合运算有如下的几个特点:

  • 会1000以内加减乘除法(通过查阅教材发现:要求掌握两位数乘除两位数)
  • 运算符在2~4个
  • 可以加括号
  • 减法运算的结果不能有负数
  • 除法运算除数不能为0,不能有余数

三、设计

1. 设计思路

说明你如何设计这个程序

  • 首先,我先分析了三年级题目的难度,确认了生成随机两位数的大小
  • 然后思考如何生成无括号的四则运算
  • 最后将括号加入,计算

2. 实现方案

写出具体实现的步骤

  • 分析了三年级题目的难度,确认了生成随机数的大小
  • 然后思考如何生成无括号的四则运算

四、编码

  • 首先我要解决的问题是,如何运算无括号的四则运算式
  • 我同样只用优先级的方法,写出Operation函数,先将* / 这种优先级较高的运算符运算,然后将运算过的符号与数值变为null,然后调用去除null的函数,将null移动至数组最后一位
  • 然后剩下的只有加减法,依次运算既可得出结果
  • 然后我们需要考虑括号因素,我打算先随机出括号的位置,与括号中的符号的数量,然后将括号内的数值与符号存入另一个数组,然后经过Operation函数运算,得出answer,然后将这些运算过的数值符号赋值null,调用removenull函数去除null
  • 然后我将已经去除括号的运算式再次使用Operation函数运算出结果

1. 调试日志

  • 在数组中存入数据,调用时发生越界,空指针

2. 关键代码

public static double Operation(String[] OpeMarkStrNumber, String[] OpeNumber) {          //首先遍历一遍存储运算符的数组,寻找到* /这种优先级较高的运算符,运算出结果,然后将运算过的符号与数值改为null,然后使用去除null的函数,去掉null数据
while(true) {
int PMAmount = 0;
for(int i = 0; i < OpeMarkStrNumber.length-1; i++) { if(OpeMarkStrNumber[i] == "*") { double ans = Double.parseDouble(OpeNumber[i]) * Double.parseDouble(OpeNumber[i+1]); OpeNumber[i] = String.valueOf(ans);
OpeNumber[i+1] = null;
OpeMarkStrNumber[i] = null;
OpeNumber = RemoveNull(OpeNumber);
OpeMarkStrNumber = RemoveNull(OpeMarkStrNumber); PMAmount++;
break; }else if(OpeMarkStrNumber[i] == "/") { double ans = Double.parseDouble(OpeNumber[i]) / Double.parseDouble(OpeNumber[i+1]);
OpeNumber[i] = String.valueOf(ans);
OpeNumber[i+1] = null;
OpeMarkStrNumber[i] = null;
OpeNumber = RemoveNull(OpeNumber);
OpeMarkStrNumber = RemoveNull(OpeMarkStrNumber);
PMAmount++;
break;
}
} if(PMAmount == 0) {
break;
}
}
return PlusMinus(OpeMarkStrNumber, OpeNumber);
} public static double PlusMinus(String[] OpeMarkStrNumber, String[] OpeNumber) { //当乘除法被消除完之后,可以依次运算加减法,最终得出结果 int PMmarkNo = 0;
double ans = Double.parseDouble(OpeNumber[0]) ;
while(true) {
if(OpeMarkStrNumber[PMmarkNo] == "+") {
ans = ans + Double.parseDouble(OpeNumber[PMmarkNo+1]);
PMmarkNo++;
}else if(OpeMarkStrNumber[PMmarkNo] == "-"){
ans = ans - Double.parseDouble(OpeNumber[PMmarkNo+1]);
PMmarkNo++;
}else if(OpeMarkStrNumber[PMmarkNo] == null){
return ans;
}
}
} public static String[] RemoveNull(String[] target) { //去除null 函数,将数组中的null移动至数组后面
for(int i = 0; i < target.length; i++) {
if(target[i] == null) {
for(int j = i; j < target.length; j++) {
if(j != target.length-1) {
target[j] = target[j+1];
}else {
target[j] = null;
}
}
}
}
return target;
}

### 3. 代码规范 请给出本次实验使用的代码规范: - 第一条:不允许任何未经预先定义的常量直接出现在代码中。
- 第二条:大括号的使用约定。如果是大括号内为空,则简介地写成{}即可,不需要换行;如果是非空代码块则:左大括号前不换行。左大括号后换行。右大括号前换行。右大括号后还有 else 等代码则不换行;表示终止的右大括号后必须换行。
- 第三条:左小括号和字符之间不出现空格;同样的,有小括号和字符之间也不出现空格。
- 第四条:在 if/else/for/while/do 语句中必须使用大括号。
- 第五条:任何二目、三木运算符的左右两边都需要加一个空格。
- 第六条:单行字符数限制不超过120个,超出需要换行,换行时遵循如下原则:第二行相对第一行缩进 4 个空格,从第三行开始,不再继续缩进,参考示例。运算符与下文一起换行。方法调用的点符号与下文一起换行。方法调用时,多个参数,需要换行时,在逗号后进行。 并人工检查代码是否符合规范 ## 五、测试 - 输入5 3 - 输出
- (1)10*(17-7)=
- (2)18*9/3=
- (3)16*3-2-10=
- (4)20/(16-15)=
- (5)20-16-18/9=
- ------------------标准答案------------------
- (1)10*(17-7)=100.0
- (2)18*9/3=54.0
- (3)16*3-2-10=36.0
- (4)20/(16-15)=20.0
- (5)20-16-18/9=2.0
## 六、总结
- 从刚看到题目时的不知所措,第一想法就是“我不会”,但是又想到这是一次结对作业,正所谓三个臭皮匠赛过诸葛亮,两个“臭皮匠"来解决这个三年级四则运算应该也绰绰有余了吧,通过相互间的讨论,解决了一些数组的越界,以及空指针的错误,节约了一些修改BUG的时间,对于不会的东西勤百度,这是解决问题的途径之一。 ![](https://img2018.cnblogs.com/blog/1472256/201809/1472256-20180919000249848-31601213.jpg)

MathExam V2.0的更多相关文章

  1. 作业2-MathExam V2.0

    MathExam V2.0 一.预估与实际 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 20 50 • ...

  2. [Android]Android端ORM框架——RapidORM(v2.0)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5626716.html [Android]Android端ORM ...

  3. JuCheap V2.0响应式后台管理系统模板正式发布beta版本

    JuCheap V1.* 查看地址: http://blog.csdn.net/allenwdj/article/details/49155339 经过半年的努力,JuCheap后台通用响应式管理后台 ...

  4. python gettitle v2.0

    #!/usr/bin/env python # coding=utf-8 import threading import requests import Queue import sys import ...

  5. ".NET Compact Framework v2.0 could not be found."

    参考: http://blog.csdn.net/godcyx/article/details/7348431 问题原因: That's a known issue where VS can't di ...

  6. 【JS】heatmap.js v1.0 到 v2.0,详细总结一下:)

    前段时间,项目要开发热力图插件,研究了heatmap.js,打算好好总结一下. 本文主要有以下几部分内容: 部分源码理解 如何迁移到v2.0 v2.0官方文档译文 关于heatmap.js介绍,请看这 ...

  7. 怎样在IDEA中使用JUnit4和JUnitGenerator V2.0自动生成测试模块

     因为项目的需要,所以研究了一下自动生成测试代码.将经验记录下来,总会有用的.我个人认为,好记性不如多做笔记多反思总结. 1.    前提条件 开发环境已正确配置 工程已解决JUnit依赖关系(pom ...

  8. 微信快速开发框架(六)-- 微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github

    4月28日,已增加多媒体上传及下载API,对应MediaUploadRequest和MediaGetRequest ------------------------------------------ ...

  9. 【原创】风讯DotNetCMS V1.0~V2.0 SQL注入漏洞

      文章作者:rebeyond 注:文章首发I.S.T.O信息安全团队,后由原创作者友情提交到乌云-漏洞报告平台.I.S.T.O版权所有,转载需注明作者. 受影响版本:貌似都受影响. 漏洞文件:use ...

随机推荐

  1. 20155207 EXP6 信息搜集与漏洞扫描

    20155207 EXP6 信息搜集与漏洞扫描 基础问题回答 1)哪些组织负责DNS,IP的管理. ICANN统一管理全球根服务器 全球根域名服务器(13台) 地区性注册机构(5个)ARIN RIPE ...

  2. git 认识

    GIT (分布式版本控制系统) <百度文库>Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目.<百度文库>                   ...

  3. Hadoop日记Day15---MapReduce新旧api的比较

    我使用hadoop的是hadoop1.1.2,而很多公司也在使用hadoop0.2x版本,因此市面上的hadoop资料版本不一,为了扩充自己的知识面,MapReduce的新旧api进行了比较研究. h ...

  4. Windows:查看IP地址,IP地址对应的机器名,占用的端口,以及占用该端口的应用程

    Windows 服务器系列: Windows:查看IP地址,IP地址对应的机器名,占用的端口,以及占用该端口的应用程 Windows:使用Dos命令管理服务(Services) Windows:任务调 ...

  5. Android Studio Xposed模块编写(二)

    阅读本文前,假设读者已经看过Android Studio Xposed模块编写(一)  相关环境已经搭建完成.本文演示案例与上文环境一致,不在赘述. 1.概述 Xposed是非常牛叉的一款hook框架 ...

  6. linux systemctl 命令

    目录 预热 管理单个 unit 查看系统上的 unit 管理不同的操作环境(target unit) 检查 unit 之间的依赖性 相关的目录和文件 systemctl daemon-reload 子 ...

  7. 2014.9.11 Research Meeting Report

    Dear All: Yesterday when we read INFOCOM papers, you have seen how damage it is to have careless wri ...

  8. LintCode——全排列

    描述:给定一个数字列表,返回其所有可能的排列. 样例:给出一个列表[1,2,3],其全排列为:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]] 说明: ...

  9. 1086. Tree Traversals Again (25)-树的遍历

    题意:用栈的push.pop操作给出一棵二叉树的中序遍历顺序,求这棵二叉树的后序遍历. 需要一个堆结构s,一个child变量(表示该节点是其父亲节点的左孩子还是右孩子),父亲节点fa对于push v操 ...

  10. 【Alpha】功能规格说明书

    更新说明:从用户需求分析中剥离有关用户场景分析部分,加入功能规格说明书. Github地址:https://github.com/buaase/Phylab-Web/blob/master/docs/ ...