Java程序设计-表达式运算(个人博客)
1、团队课程设计博客链接
洪亚文博客链接:http://www.cnblogs.com/201521123065hyw/
郑晓丽博客链接:http://www.cnblogs.com/zxl3066/
2、个人负责模块或任务说明
负责模块:整个表达式的计算流程
3、自己的代码提交记录截图
for (int i = 0; i < array.length; i++) {
for(int k=i;array[k] >= '0' && array[k] <= '9';k++,i++) {
String tmpString = array[i]+"";
System.out.println(tmpString);
numberStr.add(tmpString);//不能强制转换为double,原本的number为double类型的,因此char型的array不能直接
//在前面加double强制转换
}
if (numberStr.size() > 0) {// 通过判断存放数值的数组大小间接判断是否为数字;
for (String string : numberStr) {
numberDou.add((double) Integer.parseInt(string));
}
for (int j = numberDou.size()-1; j >= 0; j--) {
num +=numberDou.get(j) * Math.pow(10,(numberDou.size() - j-1));//超出范围的错误,number.get(j)改为j-1
//System.out.println(num);
}
value.add(num);
numberStr = null;
numberDou = null;
if (mark == 1) {
num = Calculate(sign, value, sign.pop(), num);
mark = 0;
}else if (i == array.length) {
num = Calculate(sign, value, sign.pop(), value.remove(value.size()-1));
// ///计算结果出来了!!!!!!!
}
} else {
if (array[i] == 's') {
if (array[i + 1] == 'i' && array[i + 2] == 'n') {
i = i + 2;// 原本应该为+3,但是跳出循环后还有一个自增;
sign.push("sin");
mark = 1;
continue;
} else {
String s = "Wrong Expression";
System.out.println(s);
break;
}
} else if (array[i] == 'c') {
if (array[i + 1] == 'o' && array[i + 2] == 's') {
i = i + 2;// 原本应该为+3,但是跳出循环后还有一个自增;
sign.push("cos");
mark = 1;
continue;
} else {
String s = "Wrong Expression";
System.out.println(s);
break;
}
} else if (array[i] == '^') {
sign.push("^");
mark = 1;
continue;
} else if (array[i] == '(') {
sign.push("(");
} else if (array[i] == ')') {
if (array[i - 1] == '(') {
sign.pop();
if (mark == 1) {// 考虑^()情况,mark为1证明前一个是可直接计算的符号(sin,cos,^)
num = Calculate(sign, value, sign.pop(), value.remove(value.size()-1));
value.add(num);
continue;
}
continue;
}
num = Calculate(sign, value, sign.pop(), value.remove(value.size()-1));
value.add(num);// (90*(sin80+99)-66)/7
sign.pop();
} else if (array[i] == '+' || array[i] == '-'
|| array[i] == '*' || array[i] == '/') {
if (sign.empty()) {
sign.push(array[i] + "");
} else if (compare(array[i] + "", sign.peek()) == 1) {//
sign.push(array[i] + "");
} else {
num = Calculate(sign, value, sign.pop(), value.remove(value.size()-1));
value.add(num);
}
}
}
}
}


4、自己负责模块或任务详细说明
遇到数值时进数值栈,运算符则进行优先级比较,第一个运算符一定入栈,后来的与之前的比较,当前的优先级比较大时
入栈,当前的小于或等于前面的,弹出前一个运算符和两个操作数进行运算,然后再入栈。当遇到括号的时候,左括号入栈
遇右括号时,当前面一个符号栈栈顶不是左括号时继续往前计算,知道栈顶元素为左括号,弹出左括号。接着判断,若此时
栈还不为空,接着运算
5、课程设计感想
课程设计很锻炼人,应该在平时就多积累;
我们的代码功能还不够强大,有待改进
Java程序设计-表达式运算(个人博客)的更多相关文章
- 2016-2017-2 《Java程序设计》课程学生博客和代码托管链接
2016-2017-2 <Java程序设计>课程学生博客和代码托管链接 博客 1552 20155201 李卓雯 20155202 张 旭 20155203 杜可欣 20155204 王 ...
- 2015-2016-2 《Java程序设计》项目小组博客
2015-2016-2 <Java程序设计>项目小组博客 1451 完+美 java项目 守望先疯 JavaGroup 07_10_20_22 FromBottomToTop L.G.Su ...
- java课程设计-表达式运算(团队博客)
1 团队课程设计博客 1 团队名称.团队成员介绍 团队名称 奔跑吧土拨鼠 团队成员 洪亚文 201521123065 网络1513 郑晓丽 201521123066 网络1513 2 项目git地址 ...
- 2014-2015-2 《Java程序设计》课程学生博客列表
20135101 曹钰晶 20135103 王海宁 20135104 刘 帅 20135105 王雪铖 20135109 高艺桐 20135111 李光豫 20135114 王朝宪 20135116 ...
- JAVA爬虫挖取CSDN博客文章
开门见山,看看这个教程的主要任务,就去csdn博客,挖取技术文章,我以<第一行代码–安卓>的作者为例,将他在csdn发表的额博客信息都挖取出来.因为郭神是我在大学期间比较崇拜的对象之一.他 ...
- Java课程设计——计算器团队博客
1.团队名称.团队成员介绍(需要有照片) 1.1团队名称 707 1.2团队成员介绍 谢元将:组长 罗登宇:组员 王华俊:组员 2. 项目git地址 谢元将 罗登宇 王华俊 3. 项目git提交记录截 ...
- 微博爬虫“免登录”技巧详解及 Java 实现(业余草的博客)
一.微博一定要登录才能抓取? 目前,对于微博的爬虫,大部分是基于模拟微博账号登录的方式实现的,这种方式如果真的运营起来,实际上是一件非常头疼痛苦的事,你可能每天都过得提心吊胆,生怕新浪爸爸把你的那些账 ...
- docker简单入门之使用docker容器部署简单的java web开源项目jpress博客程序
一.在centos7.3上安装docker 前置条件 x86_64-bit 系统 kernel 3.10+ .检查内核版本,返回的值大于3.10即可 [root@node1 ~]# uname -r ...
- Java电话监听器【精品博客】
模拟拨打电话,接听电话,挂断电话,拨打为空号,等等,这些动作用Java接口监听的方式来完成,主要是为了训练使用接口监听回调: /** * 业务场景一: * [萍萍]--->请输入手机号码进行拨打 ...
随机推荐
- 做的简单的一个静态web服务器,遇到个bug, 提示osError,这点一不小心就错了,特地记下来,加深记忆,socket须先绑定,再listen,如果是先listen再绑定,系统会自动分配一个端口,而程序绑定不了
代码改正之前,先执行了listen,到了bind就报错:此程序只需将listen和改到bind后面即可 from socket import *from multiprocessing import ...
- STM32F030系列实现仿位带操作
1.闲言 最近开发的时候,用到了STM32F030F4P6型号的单片机,它只有20个引脚,价格非常便宜,但是功能齐全:定时器.外部中断.串口.IIC.SPI.DMA和WWDG等等,应用尽有,非常适合用 ...
- Android 开场动画
呼,忙了两天了这个,找了各种资料,勉勉强强实现我的功能,这个还得改进一下,线程方面的知识没有学到多少,弄了线程画UI有着各种bug,无奈..就这样跳过先了,哪一天有时间在回来搞一下. 正文———— 要 ...
- 【Hadoop】执行start-dfs.sh出错
问题1:hadoop2.7.3部署警告: Unable to load native-hadoop library for your platform 解决办法: 1.编辑hadoop-env.sh ...
- 【Hibernate】版本错误 org/hibernate/Query : Unsupported major.minor version 52.0
报错原因:jdk1.7不支持 hibernate的最新版本5.2.0,把hibernate的版本换成5.1.3或更早的版本. 补充:mysql-connector-java-6.0.x也不被hiber ...
- javascript一些比较难理解的知识点
原文出处:https://segmentfault.com/a/1190000010371988 看了一下这篇文章,自己也手敲了一遍 //1. 立即执行函数 作用:将var变量的作用域限制于函数内,这 ...
- 超简单使用批处理(batch)操作数据库
超简单使用批处理(batch)操作数据库 批处理(batch)是什么 批处理的执行就好比快递员的工作: 未使用批处理的时候,快递员一次从分发点将一件快递发给客户: 使用批处理,则是快递员将所有要派送的 ...
- appium python api收集
1.contexts contexts(self): Returns the contexts within the current session. 返回当前会话中的上下文,使用后可以识别H5页面的 ...
- Southwestern Europe Regional Contest 2014 题解
时间:2017/9/8 题目8/10 Rank 5/150 体会:三星的题目和国内区域赛差距大,大多数题读懂题意就能做,所以静心读题是关键,套路性太深. A: 题意:给出一个算式,算式中的数字用大写字 ...
- localStorage sessionStorage 和cookie等前端存储方式总结
localStorage sessionStorage 和cookie localStorage localStorage是本地存储的,除非清空本地数据 localStorage不会自动把数据发给服务 ...