作业2-MathExam V2.0
- MathExam V2.0
一、预估与实际
PSP2.1 | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) |
---|---|---|---|
Planning | 计划 | 20 | 50 |
• Estimate | • 估计这个任务需要多少时间 | 20 | 50 |
Development | 开发 | 390 | 715 |
• Analysis | • 需求分析 (包括学习新技术) | 60 | 120 |
• Design Spec | • 生成设计文档 | 60 | 60 |
• Design Review | • 设计复审 | 20 | 50 |
• Coding Standard | • 代码规范 (为目前的开发制定合适的规范) | 20 | 15 |
• Design | • 具体设计 | 50 | 50 |
• Coding | • 具体编码 | 120 | 300 |
• Code Review | • 代码复审 | 50 | 120 |
• Test | • 测试 (自我测试,修改代码,提交修改) | 10 | 60 |
Reporting | 报告 | 30 | 40 |
• Test Repor | • 测试报告 | 10 | 20 |
• Size Measurement | • 计算工作量 | 10 | 10 |
• 事后总结,并提出过程改进计划 | 10 | 10 | |
Postmortem & Process Improvement Plan | 合计 |
二、需求分析
我通过观察家长们的要求了解到,小学三年级四则混合运算有如下的几个特点:
- 运算符在2~4个【进一步细化要求:至少两个不同的运算符】
- 可以加括号
- 减法运算的结果不能有负数
- 除法运算除数不能为0,不能有余数
经过分析,我认为,这个程序应当:
- 不可输入除数字外其他字符
- 注意辨别命令行参数个数
- 保留小学一年级和小学二年级计算题生成的功能,同时增加小学三年级四则混合运算的生成功能
- 随机生成括号改变优先级
三、设计
1. 设计思路
说明你如何设计这个程序
比如:
- 通过命令行接收参数
- 通过函数来随机生成题目
- 计算四则算式
- 最后生成题目与答案文件
- 关键函数是题目的生成函数认真构思
2. 实现方案
- 逆波兰表达式
四、编码
请说明你如何按照设计思路进行编码,并记录你在开发中遇到的问题,与解决过程
1. 调试日志
- 第一次编译测试,括号位置不正确
- 第二次编译测试,括号无法提高优先级
2. 关键代码
public static int Random(int Min, int Max) {
return (int) (Min + Math.random() * (Max - Min + 1));
}
public static int Calc(String Question) {
Stack<Integer> nums = new Stack<Integer>(); // 栈 保存数字
Stack<Character> opes = new Stack<Character>(); // 栈 保存操作符
String string = Question.replace(" ", "");// 获取临时字符串
char symbol;
int n = 0; // 保存每一个数字
char[] cs = string.toCharArray();// 字符串转换为char数组
for (int i = 0; i < cs.length; i++) {// 遍历char数组
char temp = cs[i];
if (Character.isDigit(cs[i])) {// 判断当前char是否为数字
n = 10 * n + Integer.parseInt(String.valueOf(temp)); // 临时保存大于10的数字
} else {// 非数字
if (n != 0) {
nums.push(n);// 数字入栈
n = 0;
}
if (temp == '(') {// 如果遇到左括号
opes.push(temp);// 入栈
} else if (temp == ')') {// 如果是遇到右括号
while (opes.peek() != '(') { // 括号里面运算完(查看堆栈顶部的对象,但不从堆栈中移除它)
symbol = opes.pop();
int t = cal(nums.pop(), nums.pop(), symbol);// 计算两个数据
if (t < 0 && symbol == '-') {
return -1;
}
if (t == 0 && symbol == '÷') {
return -1;
}
if (t < 0 && symbol == '÷') {
return -1;
}
nums.push(t);// 计算结果入栈
}
opes.pop();
} else if (isType(temp) > 0) {
if (opes.isEmpty()) { // 栈为空直接入栈
opes.push(temp);
} else {
// 若栈顶元素优先级大于或等于要入栈的元素,将栈顶元素弹出并计算,然后入栈
if (isType(opes.peek()) >= isType(temp)) {
symbol = opes.pop();
int t = cal(nums.pop(), nums.pop(), symbol);// 计算两个数据
if (t < 0 && symbol == '-') {
return -1;
}
if (t == 0 && symbol == '÷') {
return -1;
}
if (t < 0 && symbol == '÷') {
return -1;
}
nums.push(t);
}
opes.push(temp);
}
}
}
}
// 最后一个字符若是数字,未入栈
if (n != 0) {
nums.push(n);
}
while (!opes.isEmpty()) {
symbol = opes.pop();
int t = cal(nums.pop(), nums.pop(), symbol);// 计算两个数据
if (t < 0 && symbol == '-') {
return -1;
}
if (t == 0 && symbol == '÷') {
return -1;
}
if (t < 0 && symbol == '÷') {
return -1;
}
nums.push(t);
}
return nums.pop();
}
3. 代码规范:
- 采用4个空格缩进,禁止使用tab字符。
- 左小括号和字符之间不出现空格;同样的,有小括号和字符之间也不出现空格
- 注释的双斜线与注释内容之间有且仅有一个空格
- 大括号的使用约定
- 方法参数在定义和传入是,多个参数逗号后边必须加空格
- 没有必要增加若干空格来是耨一行的字符与上一行对应位置的字符对齐
- 不同逻辑、不同语义、不同业务的代码之间插入一个空行分割开来以提升可读性
- 任何二目、三木运算符的左右两边都需要加一个空格
五、测试
- 命令:
java MathExam -n 5 -Grade 1
- 输出:
(1) 40 - 38 =
(2) 2 + 38 =
(3) 81 - 10 =
(4) 42 + 57 =
(5) 79 - 17 =(1) 40 - 38 = 2
(2) 2 + 38 = 40
(3) 81 - 10 = 71
(4) 42 + 57 = 99
(5) 79 - 17 = 62
- 命令:
java MathExam -Grade 3 -n 5
- 输出:
(1) 36 × 17 + 75 ÷ 1 + 91
(2) ( 13 + 93 ) × 17
(3) 97 + 21 + 44 - 89 + 73
(4) 4 × 64 + 23 + 18 + 9
(5) 1 × 58 × 57 × 86 - 96
(1) 96 × 5 + 68 ÷ 91 + 20 = 778
(2) ( 13 + 93 ) × 17 = 1802
(3) 7 + 55 + 57 - 53 + 32 = 146
(4) 55 × 85 + 100 + 95 + 74 = 306
(5) 65 × 96 × 71 × 92 - 52 = 284220
- 命令:
java MathExam Grade 2 -n
- 输出:
Error:001
六、总结
请总结过程中的教训和经验,思考
- 结对编程相比单独编程效率更高
- 需求分析非常重要
- 掌握多门语言非常重要
- 代码目前3/4运算符加括号问题暂时没有解决,且运行时可能崩溃
作业2-MathExam V2.0的更多相关文章
- MathExam V2.0
# 隔壁村小学的小朋友都羡慕哭了2.0版 一.预估与实际 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 1 ...
- 电梯V2.0
电梯V2.0 GitHub仓库地址 Problem 一栋10层的大楼(楼层编号1-10),设3台无限载重的电梯,初始时电梯停在1层.其中:1号电梯只能停留在奇数层,2号电梯可以各层都停留,3号电梯只停 ...
- [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 ------------------------------------------ ...
随机推荐
- less的在线安装
首先打开命令行窗口windonws+r输入cmd回车 1.确认是安装了node和less,在命令行输入“node -v”回车确认node是否安装,有版本信息则安装了,输入“lessc -v”回车确认l ...
- 使用for in 循环数据集
在DELPHI没有FOR IN的语法时,我们要使用如下代码枚举数据集中的每个内容: cds.First; while not cds.eof do begin ... cds.Next; end; 最 ...
- iOS开发者证书-详解/生成/使用
本文假设你已经有一些基本的Xcode开发经验, 并注册了iOS开发者账号. 相关基础 加密算法 现代密码学中, 主要有两种加密算法: 对称密钥加密 和 公开密钥加密. 对称密钥加密 对称密钥加密(Sy ...
- django中的auth详解
Auth模块是什么 Auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等 ...
- 课程 python 文件操作复习
# 文件处理 # 打开文件 #open('路径','打开方式','指定编码方式') # 打开方式 r w a r+ w+ a+ b #r+ 打开文件直接写 和读完再写 # 编码方式 —— utf-8 ...
- CTF-安恒18年十二月月赛部分writeup
CTF-安恒十二月月赛部分writeup 这次题目都比较简单蛤,连我这菜鸡都能做几道. WEB1-ezweb2 打开网站,啥也没有,审计源代码,还是啥都没有,也没什么功能菜单,扫了一下目录,扫到了ad ...
- 工作和面试中的gdb
gdb是C/C++程序员必备的专业技能,工作中gdb最常用的场景有两个,一个是分析core文件,另一个是调试程序. 分析core文件的方法如下: 1.gdb 程序名 core文件名 2.bt或wher ...
- Makefile:(实验)多个目标匹配时会采用最完整匹配的目标
结论源自实验测试,如果有疏漏希望指出 当Makefile中存在多个匹配的目标时,Makefile会采用哪个匹配的目标呢? 测试的Makefile如下: .PHONY: all clean quick_ ...
- Mypwd 的解读与实现 20155202
Mypwd 的解读与实现 20155202 linux下pwd命令的编写 实验要求: 1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd ...
- 201552-53 《Java程序设计》第五周问题汇总
201552-53 <Java程序设计>第五周问题汇总 1.编译时,终端显示: 注:XXX.java使用了未经检查或不安全的操作,如何解决? 解答:并不是错误,可以忽视. 2.构造函数与类 ...