多数带括号计算

可以检测括号配对问题,进行多数加减乘除的运算:

import java.util.HashMap;

import java.util.Map;

import java.util.Stack;


public class Test {


static Stack<Character> opt = new Stack<Character>();// 操作符寄存器

static Stack<Integer> nums = new Stack<Integer>();// 数字寄存器

static Map<String, Integer> p = new HashMap<String, Integer>();


public static void main(String[] args) {

String str = "1+1";

System.out.println(cal("3+(4+5)*6-1+"));


}// main方法


public static int cal(String str) {


char[] cs = str.toCharArray();

p.put("(", 3);// 给符号设置优先级 3最大 0最小

p.put(")", 0);

p.put("+", 1);

p.put("-", 1);

p.put("*", 2);

p.put("/", 2);


String num = "";

for (char c : cs) {

if (c >= '0' && c <= '9') {

num += c;

} else {

if (!"".equals(num)) {

nums.push(Integer.parseInt(num));

num = "";

}

}

switch (c) {

case '(':

opt.push('(');

break;

case ')':

cal(')');

break;

case '+':

cal('+');

break;

case '-':

cal('-');

break;

case '*':

cal('*');

break;

case '/':

cal('/');

break;

}


}// for

return nums.peek();

}


public static void cal(char c) {

int num1, num2;

if (!opt.isEmpty()) {


switch (opt.peek()) {

case '(':

if (")".equals(c + "")) {

opt.pop();

} else {

opt.push(c);

}

break;

case '+':

cam('+', c);

break;

case '-':

cam('-', c);

break;

case '*':

cam('*', c);

break;

case '/':

cam('/', c);

break;

}// switch

}// if

else {

opt.push(c);

}

}


public static void cam(char pre, char now) {

if (p.get(pre + "") < p.get(now + "")) {

opt.push(now);

} else if (pre != '(') {

int num1 = nums.pop();// 第二个数

int num2 = nums.pop();// 第一个数

switch (pre) {

case '+':

nums.push(num2 + num1);

break;

case '-':

nums.push(num2 - num1);

break;

case '*':

nums.push(num2 * num1);

break;

case '/':

nums.push(num2 / num1);

break;

}

} else if (now == ')' && pre == '(') {

return;

}


opt.pop();// 先取出来再进行判断

if (!opt.isEmpty()) {


cam(opt.peek(), now);

} else {

opt.push(now);

}// if



}

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值