我是靠谱客的博主 怕孤独唇膏,最近开发中收集的这篇文章主要介绍算法设计 计算表达式的值 java,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

package day_19;
import java.util.Scanner;
import java.util.Stack;
/**
* 输入一个只包含加减乖除和括号的合法表达式,求表达式的值。其中除表示整除
* 目前暂不支持负数
* 留下注释,明天再写
* Created by IamZY on 2018/1/17.
*
* @version 1.1
*/
public class Main {
public static void main(String[] args) {
String str = "1-2+3*(4-5)";
//数字栈
Stack<Integer> number = new Stack<Integer>();
//符号栈
Stack<Character> op = new Stack<Character>();
System.out.println(expressionToResult(str, number, op));
}
public static int expressionToResult(String str, Stack<Integer> number, Stack<Character> op) {
//将str转换为char[]
char[] chars = str.toCharArray();
//遍历char数组
for (char x : chars) {
if (x == '+' || x == '-' || x == '*' || x == '/') {
int opLevel = 0;
int thisOpLevel = optionLevel(x);
//取此时符号栈顶元素的优先值和此时的入栈的符号比较
if (!op.isEmpty()) {
//栈顶符号优先级
opLevel = optionLevel(op.peek());
//若此时将入栈的符号优先级小于栈顶符号优先级 则计算
if (thisOpLevel <= opLevel) {
int n1 = number.pop();
int n2 = number.pop();
int result = calResult(op.pop(), n2, n1);
number.push(result);
op.push(x);
} else {
// 如果此时将入栈的符号优先级大于栈顶符号优先级
op.push(x);
}
} else {
//符号栈为空 不比较直接加入符号栈
op.push(x);
}
} else if (x == '(') {
op.push(x);
} else if (x == ')') {
//出现右括号 找符号栈中的左括号
while (true) {
char opStack = op.pop();
if (opStack == '(') {
break;
} else {
//不是左括号就把()之间的数据运算
int n1 = number.pop();
int n2 = number.pop();
//将结果放回数据栈
number.push(calResult(opStack, n2, n1));
}
}
} else if (Character.isDigit(x)) {
//数字进栈
number.push(Integer.parseInt(String.valueOf(x)));
}
} //增强for...
// 遍历完表达式 栈中可能还有符号
while (true) {
if (op.isEmpty()) {
break;
} else {
int n1 = number.pop();
int n2 = number.pop();
number.push(calResult(op.pop(), n2, n1));
}
}
return number.pop();
}
//计算两个数的值
public static int calResult(char c, int x, int y) {
switch (c) {
case '+':
return x + y;
case '-':
return x - y;
case '*':
return x * y;
case '/':
return x / y;
default:
return -1;
}
}
//判断符号优先级的方法
public static int optionLevel(char c) {
switch (c) {
case '+':
case '-':
return 1;
case '*':
case '/':
return 2;
default:
return 0;
}
}
}

最后

以上就是怕孤独唇膏为你收集整理的算法设计 计算表达式的值 java的全部内容,希望文章能够帮你解决算法设计 计算表达式的值 java所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部