【week2】结对编程-四则运算 及感想
首先我要说一下,我得作业我尽力了,但是能力有限,还需练习。
四则运算,改进代码流程:
1.手动输入算式(属于中缀表达式)
2.将中缀表达式转化成后缀表达式 生成out数组
3.一个操作数栈,一个运算符栈,按照后缀表达式计算方法将out中的字符分别放入两个栈
4.当操作数栈只有一个数时结束计算。
代码分段解析如下:
中缀变后缀:
public List<String> SolveOrder(String[] in,HashMap<String,Integer>precedence){
//符合逆波兰式(后缀)的输出
List<String> out = new ArrayList<String>();
//操作符
Stack<String> ops= new Stack<String>();
for(int i=0;i<in.length;i++){
String s=in[i];
//碰见数值 就放进out数组末尾
if(!precedence.containsKey(in[i])){
out.add(s);
continue;
}
while(true){
//当存储操作符的栈中“空”或“遇见左括号”或“栈顶的运算符优先级
// 小于读取字符串当前字符的优先级”时,符号入栈
if(ops.isEmpty()||s.equals("(")||(precedence.get(s)
>precedence.get(ops.peek()))){
ops.push(s);
break;
}
String op=ops.pop();//出栈得运算符
if(op.equals("(")){
break;
}else{
out.add(op);
}
}
}
//若操作符栈不为空,就依次将剩余的操作符放入out数组
while(!ops.isEmpty()){
out.add(ops.pop());
}
return out;
}
根据后缀(逆波兰式)计算。
public double calculateOut(String[] out) {
//假设满足逆波兰式的输出不为空却长度不为零
assert (out != null && out.length != 0);
//操作数栈
Stack<Double> stack = new Stack<Double>();
for (int i = 0; i < out.length; i++) {
if (isNumber(out[i])) {
stack.push(Double.parseDouble(out[i]));
} else {
double v1 = stack.pop();
double v2 = stack.pop();
double result = eval(out[i], v2, v1);
stack.push(result);
}
}
return stack.pop();
}
主函数:控制台输入完整算式。
public static void main(String[] args) {
System.out.println("请输入要计算的算式:");
Scanner sc= new Scanner(System.in);
String inBefor = sc.nextLine();
String[] in=inBefor.split("");
Cal cc = new Cal();
HashMap<String, Integer> precedence=cc.priorityInfo();;
cc.SolveOrder(in, precedence);
System.out.println("所输入的算式结果为:"+cc.calculateOut(in));
}
老师,这段代码我是看的别人博客上写的,只能说我看懂了,还没到您要求的变成自己的,但是,老师 ,我实在写不动了。。
关于结对编程,从上这门课是从无到有的认识。编程这种东西就像思想,两个人share就是两个人都有两种。争吵中才会进步。
1.最开始的争论是关于用java还是c++?由于我俩未来可能想更多的使用java所以,最后决定用java。
2.关于复杂运算有两种思想:对五个数字产生的四个运算符 进行讨论,四个位置分别讨论+—*/另一种就是使用堆栈进行计算,最后还是堆栈代码量比较小,选定!
3.关于数字与符号的存储方式,一种是用类,一种是分为两个数组。用类,在处理数组与字符的int String类型上不方便,最后决定用两个数组。
4.最后的代码加不加原来的两个操作数的代码,最后没加。
5.代码还有一点问题,发不发博客?最后还是发了。。。

结语:我去睡觉了,现在已经5:27了
代码地址:https://git.coding.net/yumiaomiao/Arithmetic.git
ssh:git@git.coding.net:yumiaomiao/Arithmetic.git
【week2】结对编程-四则运算 及感想的更多相关文章
- 20175226 2018-2019-2《java程序设计》结对编程-四则运算(第一周-阶段总结)
结对编程-四则运算(第一周-阶段总结) 需求分析 实现一个四则运算程序,要求: 自动随机生成小学四则运算题目(加,减,乘,除) 支持整数.真分数且支持多项式 能够利用栈的思想,将中缀转换为后缀表达式 ...
- 20175305张天钰Java结对编程四则运算(二)
Java结对编程四则运算(二) 一.题目描述及要求 Git提交粒度不要太粗,建议一个文件/一个类/一个函数/一个功能/一个bug修复都进行提交,不能一天提交一次,更不能一周一次,参考Commit Me ...
- 20175305张天钰Java结对编程四则运算
Java结对编程四则运算 一.题目描述:如何对表达式进行求值运算呢 1.中缀表达式与后缀表达式(娄老师讲解) 中缀表达式就是运算符号在运算数中间的表达式,比如1+2,顾名思义,后缀表达式就是运算符在运 ...
- 结对编程--四则运算(Java)萧英杰 夏浚杰
结对编程--四则运算(Java)萧英杰 夏浚杰 Github项目地址 功能要求 题目:实现一个自动生成小学四则运算题目的命令行程序 使用 -n 参数控制生成题目的个数(实现) 使用 -r 参数控制题目 ...
- 结对编程--四则运算(Java)梅进鹏 欧思良
结对编程--四则运算(Java)梅进鹏 欧思良 Github项目地址:https://github.com/MeiJinpen/Arithmetic 功能要求 题目:实现一个自动生成小学四则运算题目的 ...
- 王译潇20162314 实验报告三plus结对编程四则运算第一阶段
北京电子科技学院BESTI实验报告 课程:程序设计与数据结构 班级: 1623 姓名: 王译潇 学号:20162314 指导教师:娄佳鹏老师.王志强老师 实验日期:2017年5月12号 实验密级: 非 ...
- Java结对编程四则运算一周小结
Java结对编程四则运算一周小结 需求分析 对于四则运算来说最主要的就是要计算出产生的式子(字符串的形式). 设计思路 总体可将这个项目分解为几个部分:产生式子,计算式子,判断对错并记录: 具体的思路 ...
- 结对编程四则运算gui
码市地址:https://git.coding.net/linzhao/sizeyunsuangui.git 林 钊 -- 201421123105 吴世荣 -- 201421123119 王坤彬 - ...
- 结对编程-四则运算-GUI
201421123022 王若凡 201421123026 欧阳勇 https://git.coding.net/ttoyy/sizeyunsuan-GUI.git a.需求分析: ...
随机推荐
- ELK的端口以及加入x-pack的密码问题
ElasticSearch的端口: http://localhost:9200 http://localhost:9200/_plugin/head Kibana的端口: http://localho ...
- Python3练习:对员工信息文件,实现增删改查操作
1.练习要求: 2.数据文件(data_staff.txt) 1,Alex Li,22,13651054684,运维,2013-02-04 2,Jack Wang,20,13312331232,HR, ...
- LeetCode二叉树实现
LeetCode二叉树实现 # 定义二叉树 class TreeNode: def __init__(self, x): self.val = x self.left = None self.righ ...
- nodejs module/require
1. wrap up a module using module.exports, name the file to a.js var fun1=function(){ var stylus = re ...
- NoSQL入门第四天——事务与主从复制
一.Redis的事务 1.是什么 可以一次执行多个命令,本质是一组命令的集合.一个事务中的 所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞 (更多请参见官网事务介绍) 2.能干什 ...
- VR中为什么需要把游戏音频放在聚光灯里?
VR中为什么需要把游戏音频放在聚光灯里? 本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/de ...
- Hibernate-关系映射
1.为什么用Hibernate框架: java程序数据保存的变化: * 内存存在:java基础中, 数据保存在内存中,只在内存中暂时存在 * 文件保存:有io/流之后,数据可以保存到文件中 * 数据库 ...
- Aop实现拦截方法参数
对于spring框架来说,最重要的两大特性就是AOP 和IOC. 以前一直都知道有这两个东西,在平时做的项目中也常常会涉及到这两块,像spring的事务管理什么的,在看了些源码后,才知道原来事务管理也 ...
- 仿京东淘宝商品详情页属性选择js效果
在网上找了好久发现都不符合要求就自己摸索写了一个,用到了linq.js这个linq to js 扩展,不然用纯JS遍历json查询要死人啊 demo:http://123.207.28.46:8086 ...
- K8S全栈容器服务如何助力企业云化创新?
容器编排管理平台Kubernetes在实践两年多后,市场主导地位被正式确定,随着首批认证服务商的宣布,围绕着容器的应用编排部署服务已然成熟,Kubernetes开始在商业场景为企业创造价值.华为云在K ...