MathExam V2.0
隔壁村小学的小朋友都羡慕哭了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的时间,对于不会的东西勤百度,这是解决问题的途径之一。

MathExam V2.0的更多相关文章
- 作业2-MathExam V2.0
MathExam V2.0 一.预估与实际 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 20 50 • ...
- [Android]Android端ORM框架——RapidORM(v2.0)
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5626716.html [Android]Android端ORM ...
- JuCheap V2.0响应式后台管理系统模板正式发布beta版本
JuCheap V1.* 查看地址: http://blog.csdn.net/allenwdj/article/details/49155339 经过半年的努力,JuCheap后台通用响应式管理后台 ...
- python gettitle v2.0
#!/usr/bin/env python # coding=utf-8 import threading import requests import Queue import sys import ...
- ".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 ...
- 【JS】heatmap.js v1.0 到 v2.0,详细总结一下:)
前段时间,项目要开发热力图插件,研究了heatmap.js,打算好好总结一下. 本文主要有以下几部分内容: 部分源码理解 如何迁移到v2.0 v2.0官方文档译文 关于heatmap.js介绍,请看这 ...
- 怎样在IDEA中使用JUnit4和JUnitGenerator V2.0自动生成测试模块
因为项目的需要,所以研究了一下自动生成测试代码.将经验记录下来,总会有用的.我个人认为,好记性不如多做笔记多反思总结. 1. 前提条件 开发环境已正确配置 工程已解决JUnit依赖关系(pom ...
- 微信快速开发框架(六)-- 微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github
4月28日,已增加多媒体上传及下载API,对应MediaUploadRequest和MediaGetRequest ------------------------------------------ ...
- 【原创】风讯DotNetCMS V1.0~V2.0 SQL注入漏洞
文章作者:rebeyond 注:文章首发I.S.T.O信息安全团队,后由原创作者友情提交到乌云-漏洞报告平台.I.S.T.O版权所有,转载需注明作者. 受影响版本:貌似都受影响. 漏洞文件:use ...
随机推荐
- cmake源码包安装后的卸载问题
cmake源码包安装 CMake是一个跨平台的安装(编译)工具,可以用简单的语句来描述所有平台的安装(编译过程),具体学习请移步官网CMake 本文介绍的就是用cmake去安装的别人的包. 一般流程: ...
- 浅谈Objeact.clone克隆(纯个人理解,如有错误请指正)
现在先来看一下jdk给出的Object.clone源码和注释 /** * Creates and returns a copy of this object. The precise meaning ...
- SSIS 连接数据
通常情况下,ETL方案需要同时访问两个或多个数据源,并把结果合并为单个数据流,输出到目标表中.为了向目标表中提供统一的数据结构,需要把多个数据源连接在一起.数据连接的另外一种用法,就是根据现有的数据, ...
- sql优化详细介绍学习笔记
因为最近在面试,发现sql优化这个方面问的特别特别的多.之前都是零零星星,不够全面的了解一点,刚刚在网上查了一下,从 http://blog.csdn.net/zhushuai1221/article ...
- IIS充当反向代理转发请求到Kestrel
接着上篇博文为ASP.NetCore程序启用SSL的code,这篇将介绍如何用IIS充当反向代理的角色转发请求到Kestrel服务器 介绍 与ASP.NET不同,ASP.netCore使用的是自托管w ...
- 管理idea Open Recent
在微服务开发过程中,随着服务的增加,日常需要在各个服务之间切换,这样idea 的 Open Recent 功能就显得特别有用,但是过多的最近打开记录中包括已经删除的工程或者无用的工程导致影响开发时切换 ...
- 团队作业week9
1. Bug bash ▪ How many bugs is found in your bug bash? 2. Write a blog to talk about your scenario t ...
- Linux内核分析第一周——计算机是如何工作的
冯诺依曼体系结构 核心思想 1.冯诺依曼是:数字计算机的数制采用二进制:计算机应该按照程序顺序执行. 2.采用二进制作为计算机数值计算的基础,以0.1代表数值.不采用人类常用的十进制计数方法,二进制使 ...
- rethinking virtual network embedding..substrate support for path splitting and migration阅读笔记
1.引言 网络虚拟化, 1.支持同一个底层网络有多种网络架构,每种架构定制一个应用或用户社区. 2.也可以让多个服务提供者在共同的物理基础设施上定制端到端的服务.如Voice over IP(VoIP ...
- iOS 内存管理-copy、 retain、 assign 、readonly 、 readwrite、nonatomic、@property、@synthesize、@dynamic、IB_DESIGNABLE 、 IBInspectable、IBOutletCollection
浅谈iOS内存管理机制 alloc,retain,copy,release,autorelease 1)使用@property配合@synthesize可以让编译器自动实现getter/setter方 ...