表达式求值

分为三块,一块处理数字,一块处理括号,一块处理符号。最后将数字加起来放入list即可。

对于上述两个要求,我们要考虑的是两点,一是处理运算优先级的问题,二是处理括号的问题。

处理优先级问题,那必定是乘号有着优先运算的权利,加号减号先一边看,我们甚至可以把减号看成加一个数的相反数,则这里只有乘法和加法,那我们优先处理乘法,遇到乘法,把前一个数和后一个数乘起来,遇到加法就把这些数字都暂时存起来,最后乘法处理完了,就剩余加法,把之前存起来的数字都相加就好了。

处理括号的问题,我们可以将括号中的部分看成一个新的表达式,即一个子问题,因此可以将新的表达式递归地求解,得到一个数字,再运算。

step 1:使用栈辅助处理优先级,默认符号为加号。 step 2:遍历字符串,遇到数字,则将连续的数字字符部分转化为int型数字。 step 3:遇到左括号,则将括号后的部分送入递归,处理子问题;遇到右括号代表已经到了这个子问题的结尾,结束继续遍历字符串,将子问题的加法部分相加为一个数字,返回。 step 4:当遇到符号的时候如果是+,得到的数字正常入栈,如果是-,则将其相反数入栈,如果是*,则将栈中内容弹出与后一个元素相乘再入栈。 step 5:最后将栈中剩余的所有元素,进行一次全部相加。

 public ArrayList<Integer> function(String s,int index){
        Stack<Integer> stack=new Stack<Integer>();
        int num=0;
        char op='+';
        int i;
        for (i=index;i<s.length();i++){
            if(s.charAt(i)>='0'&&s.charAt(i)<='9'){
                num=num*10+s.charAt(i)-'0';
                if(i!=s.length()-1) continue;
            }

            if(s.charAt(i)=='('){
                ArrayList<Integer> res=function(s,i+1);
                num=res.get(0);
                i= res.get(1);
                if(i!=s.length()-1) continue;

            }

            switch (op){

                case '+':
                    stack.push(num);
                    break;
                case '-':
                    stack.push(-num);
                    break;
                case '*':
                    int temp= stack.pop();
                    stack.push(temp*num);
                    break;
            }
            num=0;
            if(s.charAt(i)==')') break;
            else op=s.charAt(i);
        }

        int sum=0;
        while (!stack.isEmpty()) sum+=stack.pop();
        ArrayList<Integer> temp=new ArrayList<Integer>();
        temp.add(sum);
        temp.add(i);
        return temp;

    }

    public int solve (String s) {
        // write code here
        ArrayList<Integer> list=function(s,0);
        return list.get(0);
    }
全部评论

相关推荐

03-03 19:02
已编辑
东华理工大学 Node.js
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
10999次浏览 94人参与
# 你的实习产出是真实的还是包装的? #
1943次浏览 42人参与
# 巨人网络春招 #
11361次浏览 223人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7628次浏览 43人参与
# 简历第一个项目做什么 #
31736次浏览 339人参与
# 重来一次,我还会选择这个专业吗 #
433535次浏览 3926人参与
# 米连集团26产品管培生项目 #
6025次浏览 216人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187190次浏览 1122人参与
# 牛客AI文生图 #
21445次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152440次浏览 888人参与
# 研究所笔面经互助 #
118959次浏览 577人参与
# 简历中的项目经历要怎么写? #
310347次浏览 4217人参与
# AI时代,哪些岗位最容易被淘汰 #
63800次浏览 826人参与
# 面试紧张时你会有什么表现? #
30508次浏览 188人参与
# 你今年的平均薪资是多少? #
213127次浏览 1039人参与
# 你怎么看待AI面试 #
180119次浏览 1258人参与
# 高学历就一定能找到好工作吗? #
64331次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76533次浏览 374人参与
# 我的求职精神状态 #
448120次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363501次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160672次浏览 1112人参与
# 校招笔试 #
471128次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务