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、课程设计感想

课程设计很锻炼人,应该在平时就多积累;
我们的代码功能还不够强大,有待改进
posted @ 2017-06-22 20:15  066xiao  阅读(320)  评论(0编辑  收藏  举报