公式字符串求值

import java.util.Deque;
import java.util.LinkedList;

/**
 * Created by lxw, liwei4939@126.com on 2017/11/1.
 * 公式字符串求值
 */
public class stringValue {
    
    public int getValue(String str){
        return value(str.toCharArray(), 0)[0];
    }
    
    public int[] value(char[] chars, int i){
        Deque<String> deq = new LinkedList<String>();
        int pre = 0;
        int[] bar = [];
        while (i < chars.length && chars[i] != ')'){
            if(chars[i] > '0' && chars[i] < '9'){
                pre = pre * 10 + chars[i++] - '0';
            } else if(chars[i] != '('){
                addNum(deq, pre);
                deq.addLast(String.valueOf(chars[i++]));
            } else {
                bar = value(chars, i+1);
                pre = bar[0];
                i = bar[1] + 1;
            }
        }
        addNum(deq, pre);
        return int[]{getNum(deq), i};
    }
    
    public void addNum(Deque<String> deque, int num){
        if(!deque.isEmpty()){
            int cur = 0;
            String top = deque.pollLast();
            if(top.equals("+") || top.equals("-")){
                deque.addLast(top);
            } else {
                cur = Integer.valueOf(deque.pollLast());
                num = top.equals("*") ? (cur * num) : (cur / num);
            }
        }
        deque.addLast(String.valueOf(num));
    }
    
    public int getNum(Deque<String> deque){
        int res = 0;
        boolean add = true;
        String cur = null;
        int num = 0;
        while (!deque.isEmpty()){
            cur = deque.pollFirst();
            if(cur.equals("+")){
                add= true;
            } else if(cur.equals("-")){
                add = false;
            } else {
                num = Integer.valueOf(cur);
                res += add ? num : (-num);
            }
        }
        return res;
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值