20172313『Java程序设计』课程结对编程练习_四则运算第二周阶段总结
20172313『Java程序设计』课程结对编程练习_四则运算第二周阶段总结
结对伙伴
- 20172326康皓越
- 博客地址(http://www.cnblogs.com/326477465-a/p/9011498.html)
- 20172332于欣月
- 博客地址(http://www.cnblogs.com/yu757503836/p/9011486.html)
小组结对编程照片

个人贡献度划分
| 余坤澎 | 于欣月 | 康皓越 | |
|---|---|---|---|
| 个人贡献度 | 30% | 40% | 30% |
设计思路
- 设计一个num类和一个Elements类用于生成数字和String类型的运算符。
- 设计一个expression类调用num类和Elements中的方法,利用if语句根据用户输入的题目难度等级和题目个数来生成表达式。
- 设计一个Cal类进行计算,先对表达式进行处理,把中缀表达式转换为后缀表达式,在用后缀表达式计算出表达式的值。在该类中添加一个能够判断用户输入答案正否正确的方法。
- 设计一个用户测试类选择难度和题目个数,输入用户计算的值与正确答案进行比较,如果正确,返回答案正确;如果错误,返回答案错误并返回正确答案。
关键代码解释
Elements p = new Elements();
Num w = new Num();
w.getNum();
if (count1 != 0 && count2 != 0)
result = result;
else if (count1 == 0) {
Random m = new Random();
int n = m.nextInt(2);
//选择加还是减
if (n == 0) {
p.add();
result += p + w.toString();
} else {
p.sub();
result += p + w.toString();
}
} else {
Random m = new Random();
int n = m.nextInt(2);
//选择乘还是除
if (n == 0) {
p.mul();
result += p + w.toString();
} else {
p.div();
result += p + w.toString();
}
}
}
- 分别判断是否有无加减或乘除,并进行相应的随机添加加减或者乘除法,以保证达到混合运算的目的。
if (count == 0) {
int iw = a.nextInt(2);
if (iw == 0) {
cd.mul();
b.getNum();
result += cd + b.toString();
} else {
cd.div();
b.getNum();
result += cd + b.toString();
}
} else {
result = result;
}
- 判断整个式子是否有乘除法,并添加相应的乘除法,以达到混合运算的目的。
public List<String> InfixToPostfix(List<String> list){
List<String> Postfixlist = new ArrayList<String>();//存放后缀表达式
Stack<String> stack = new Stack<String>();//暂存操作符
//stack.push('#');
for(int i=0;i<list.size();i++){
String s = list.get(i);
if(s.equals("(")){
stack.push(s);
}else if(s.equals("*")||s.equals("/")||s.equals("÷")){
stack.push(s);
}else if(s.equals("+")||s.equals("-")){
if(!stack.empty()){
while(!(stack.peek().equals("("))){
Postfixlist.add(stack.pop());
if(stack.empty()){
break;
}
}
stack.push(s);
}else{
stack.push(s);
}
}else if(s.equals(")")){
while(!(stack.peek().equals("("))){
Postfixlist.add(stack.pop());
}
stack.pop();
}else{
Postfixlist.add(s);
}
if(i==list.size()-1){
while(!stack.empty()){
Postfixlist.add(stack.pop());
}
}
}
return Postfixlist;
}
- 利用栈使中缀表达式转换为后缀表达式。
public double doCal(List<String> list){
Stack stack = new Stack();
for(int i=0;i<list.size();i++){
String s = list.get(i);
double t=0;
if(!isOp(s)){
Double cd = Double.parseDouble(s);
t = cd;
stack.push(t);
}else{
if(s.equals("+")){
double a1 = (double) stack.pop();
double a2 = (double) stack.pop();
double v = a2+a1;
stack.push(v);
}else if(s.equals("-")){
double a1 = (double) stack.pop();
double a2 = (double) stack.pop();
double v = a2-a1;
stack.push(v);
}else if(s.equals("*")){
double a1 = (double) stack.pop();
double a2 = (double) stack.pop();
double v = a2*a1;
stack.push(v);
}else if(s.equals("/")||s.equals("÷")){
double a1 = (double) stack.pop();
double a2 = (double) stack.pop();
double v = a2/a1;
stack.push(v);
}
}
}
return (double) stack.pop();
}
- 利用栈计算后缀表达式的值。
public void torf(List<String> list){
Scanner scan = new Scanner(System.in);
System.out.println("请输入计算结果");
String result = scan.nextLine();
double result2 = Double.parseDouble(result);
if (result2 - doCal( list)<0.001 && result2 - doCal(list)> -0.001)
System.out.println("答案正确");
else
System.out.println("答案错误" + " " + "正确答案为" + doCal(list));
}
- 在允许一定范围的误差内来判断用户输入的答案是否正确。
遇到的困难及解决方法
- 问题1:利用随机生成表达式等级三的时候,因为是随机生成的运算符,所以不能保证生成的表达式中乘除都存在。
- 问题1解决方法:定义这样一个方法,如果随机到乘除,定义一个count变量进行自加,从而使用if语句由count的值来判断缺少什么运算符,如有缺少添加上缺少的相应的运算式。

- 问题2:一开始的时候除号与分数的分号是一致的,所以生成的表达式中的区分度不够,不能够很好的表示真分数。
- 问题2解决方法:在生成表达式的时候新加一种情况是字符串型“÷”,在运算的时候,在相应的数组中添加“÷”,并且把“÷”定义成与“/”一样的计算。


- 问题3:在用户测试类中调用运算类的时候,生成的答案与正确答案有时候会出现不一致。


- 问题3在当天进行调试的时候尚未解决,在后续的编程中会找出并解决问题,体现在下一次的博客中。
文件扩展
在完成了基本要求之后,考虑实现以下功能。
- 实现支持多语言。
- 能够实现题目去重。
- 对生成的题目和用户输入的结果以及正确结果和正确率进行记录并在txt文本中进行体现。
项目链接
PSP时间统计:
| PSP2.1 | Personal Software Process Stages | 预估耗时(小时) | 实际耗时(小时) |
|---|---|---|---|
| Planning | 计划 | 1 | 1.5 |
| Estimate | 估计这个任务需要多少时间 | 1 | 1 |
| Development | 开发 | 6 | 10 |
| Analysis | 需求分析 (包括学习新技术) | 1 | 3 |
| Coding Standard | 代码规范 (为目前的开发制定合适的规范) | 1 | 3 |
| Design UML | 设计项目UML类图 | 1.5 | 1.5 |
| Coding | 具体编码 | 6 | |
| Code Review | 代码复审 | 2 | 3 |
| Test | 测试(自我测试,修改代码,提交修改) | 2 | 2 |
| Size Measurement | 计算工作量(实际时间) | 2 | 1 |
| Postmortem & Process Improvement Plan | 事后总结, 并提出过程改进计划 | 1 | 1 |
| 合计 | 26.5 | 33 |
20172313『Java程序设计』课程结对编程练习_四则运算第二周阶段总结的更多相关文章
- 20172332『Java程序设计』课程结对编程练习_四则运算第二周阶段总结
20172313『Java程序设计』课程结对编程练习_四则运算第二周阶段总结 小组成员 20172326康皓越 20172313余坤澎 20172332于欣月 小组编程照片 设计思路 设计一个生成符号 ...
- 20172326『Java程序设计』课程结对编程练习_四则运算第二周阶段总结
20172326『Java程序设计』课程结对编程练习_四则运算第二周阶段总结 小组成员 20172313 余坤澎 20172332 于欣月 20172326 康皓越 小组编程照片 设计思路 通过一个E ...
- 20172311『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结
20172311『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号 :20172307 姓名 :黄宇瑭 伙伴第一周博客地址 对结对伙伴的评价:黄宇瑭同学的优势在于能够想出一 ...
- 20172321『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结
20172321『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号 :20172324 姓名 :曾程 伙伴第一周博客地址: 对结对伙伴的评价:一个很优秀的同学,在这次项目中 ...
- 20172325『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结
20172325『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结 结对伙伴 学号:20172306 姓名:刘辰 结对伙伴博客链接 刘辰同学对编程的积极程度很高,并且在编程能力上很不错,有 ...
- 20172302『Java程序设计』课程 结对编程练习_四则运算第二周阶段总结
一.结对对象 姓名:周亚杰 学号:20172302 担任角色:驾驶员(周亚杰) 伙伴第二周博客地址 二.本周内容 (一)继续编写上周未完成代码 1.本周继续编写代码,使代码支持分数类计算 2.相关过程 ...
- 20172311『Java程序设计』课程 结对编程练习_四则运算第一周阶段总结
20172311『Java程序设计』课程 结对编程练习_四则运算第一周阶段总结 结对伙伴 学号 :20172307 姓名 :黄宇瑭 伙伴第一周博客地址: http://www.cnblogs.com/ ...
- 2017-2018-2 1723 『Java程序设计』课程 结对编程练习_四则运算 第二周
一.结对对象 姓名:侯泽洋 学号:20172308 担任角色:驾驶员(侯泽洋) 伙伴第二周博客地址 二.本周内容 (一)继续编写上周未完成代码 1.本周继续编写代码,使代码支持分数类计算 2.相关过程 ...
- 2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算——第一周
2017-2018-20172309 『Java程序设计』课程 结对编程练习_四则运算 组队成员: 仇夏 学号: 20172310 博客地址:点击这里 1. 需求分析: 可生成题目: - 输入要想生成 ...
随机推荐
- 在线调整InnoDB Buffer Pool Size
InnoDB Buffer Pool主要是用来缓存数据表和索引数据的内存区域,它的默认值为134217728字节(128MB).最大值取决于CPU架构;32位系统上的最大值为4294967295(23 ...
- go 数组、切片
数组定义 // 标准 ]], , , , } fmt.Println("a", a) // 自动推导类型 b := [], , , , } fmt.Println(&qu ...
- springboot-web进阶(二)——AOP统一处理请求
一.AOP使用示例 AOP的概述在spring篇已经存在,这里不再赘述 1.准备 引入依赖 <dependency> <groupId>org.springframework. ...
- 2 vue 。js
元素option el element 混淆 webpack 项目依赖 save 开发依赖 虚拟dom的问题 在js的基础上封装的,不是jquery 整个网页就一个实例化对象 v 下一张 怎么做 ...
- [ONTAK2010]Peaks kruskal重构树,主席树
[ONTAK2010]Peaks kruskal重构树练手题. LG传送门竟然不强制在线?看到离线水过很不爽:B站强制在线版传送门 看到"询问从点\(v\)开始只经过困难值小于等于\(x\) ...
- 轻量级企业私有云 JimV 分享
当前云市场分析 云分两种,公有云.私有云.目前市面上的云产品,对于中小规模的企业来讲,痛点有如下几点: 私有云: 1.VMware ESXi 类: a) 授权费用昂贵: b) 创建虚拟机费时费力: 2 ...
- Flutter - 下载别人的Flutter项目,本地编译不过
如果直接下载了别人的Flutter项目,点击运行基本会不通过的,这是gradle版本差异造成的. 你需要修改android/gradle/wrapper/gradle-wrapper.properti ...
- 流行创意风格教师求职简历免费word模板
18款流行创意风格教师求职简历免费word模板,也可用于其他专业和职业,个人免费简历模板,个人简历表免费,个人简历表格. 声明:该简历模板仅用于个人欣赏使用,请勿用于商业用途,谢谢. 下载地址:百度网 ...
- @RestController注解
@RestController注解其实就是@@Controller和@ResponseBody的组合:RESTFUL风格 看下源码: 当@ResponseBody放到Controller类上,改Con ...
- Kubernetes 容器平台实战
一.什么是Kubernetes? Kubernetes是容器集群管理系统,是一个开源的平台,可以实现容器集群的自动化部署,自动扩缩容,维护等功能. 通过Kubernetes可以做到: 快速部署应用 快 ...