作业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 ------------------------------------------ ...
随机推荐
- Storm相关笔记(包括Kafka和HBase)
一.Apache Kafka 1.了解Kafka 1.1.Kafka是什么?有什么用? 是什么? 1) Apache Kafka 是一个消息队列(生产者消费者模式) 2) Apache Kafka 目 ...
- UITextView 光标定位
在使用UITextView的时候, 如何在光标的位置插入字符 或者 图片? 以下Demo为你解答: 应用背景:键盘自定义emoji表情 #pragma mark - KVO - (void)obser ...
- PE 学习之路 —— 区块表
1. 前述 在 NT 头结束后,紧接着就是区块表,区块表包含每个块在映象中的信息,分别指向不同的区块实体. 2. 区块表 区块表是一个 IMAGE_SECTION_HEADER 结构数组,这个结构包含 ...
- 07.centos7构建 IntelliJ IDEA(简称IDEA)开发环境
一.安装IDEA 进入官网下载linux版的社区便,IDEA分为社区版和旗舰版,社区版免费,并且基本满足spark开发需求. 解压安装 目录为/opt/idea 注意:centos命令行界面下是无法安 ...
- Leecode刷题之旅-C语言/python-263丑数
/* * @lc app=leetcode.cn id=263 lang=c * * [263] 丑数 * * https://leetcode-cn.com/problems/ugly-number ...
- 那些年我们追过的C#奇葩关键字——忐忑
说到中国的歌坛,不能光说张学友这种大咖吧,我看那些怪咖更给力,比如我们的龚琳娜童鞋,一首神曲<忐忑>唱的那叫不可收拾,而且听到的改编版本更多,每一次都是心怀忐忑,就像C#里的那些关键字 说 ...
- Could not connect to '192.168.80.145' (port 22): Connection failed的解决办法(远程连不上xshell)
问题状况表现1 这个问题一般是你 的什么配置影响了虚拟机的网卡网关设置!!!. 问题状况表现2 这个问题一般是你 的什么配置影响了虚拟机的网卡网关设置. 解决办法 网上的那些解决方案,我都试过,比如. ...
- 【LG5020】[NOIP2018]货币系统
[LG5020][NOIP2018]货币系统 题面 洛谷 题解 考场上第一眼还不会233 可以发现只要可以被其他的货币通过一些奇奇怪怪的方式表示出来的货币就\(ban\)掉即可 就是个完全背包 我是统 ...
- js创建对象 object.create()用法
Object.create()方法是ECMAScript 5中新增的方法,这个方法用于创建一个新对象.被创建的对象继承另一个对象的原型,在创建新对象时可以指定一些属性. 语法: Object.crea ...
- kobject和kset的一些学习心得
#include <linux/module.h> #include <linux/kernel.h> #include <linux/kobject.h> #in ...