【HUAWEI OJ 题库】表达式计算

题目描述

四则运算表达式可用表达式树来表达,如下图所示。
在这里插入图片描述
图中最右边部分是该表达式树的后序遍历(后序遍历是指先遍历左子树,再遍历右子树,最后访问节点本身,简写 LRN)。现给你一个字符串,代表一个后序遍历形式的四则运算表达式,请计算出表达式的结果(只输出整数部分)。

注:

都是双目运算,不存在单目运算;
中间计算结果范围:[-2^31, 2^31);
除法只需保留整数部分,比如:5/4=1, (-5)/3=-1, 5/(-3)=-1,无需考虑余数;无需考虑除数为0的情况,用例不存在除零。
解答要求
时间限制:1000ms, 内存限制:64MB
输入
一个字符串,代表一个四则运算表达式,由若干操作数和运算符组成,操作数、运算符之间都用一个逗号隔开。长度范围:[1,50000)。
注:用例保证输入合法:1)一定有计算结果; 2)操作数是合法的整数; 3)运算符只包含+,-,*,/四种。
输出
一个整数,表示表达式的计算结果,用例保证最终结果范围:-2,147,483,648 ~ 2,147,483,647。
样例
输入样例 1

9,3,5,-,2,*,+

输出样例 1

5

输入样例 2

3,-3,-,2,/,10,-

输出样例 2

-7

提示

样例1解释:算式结构为:(3 - 5) * 2 + 9 = 5

样例2解释:算式结构为:(3 - (-3)) / 2 - 10 = -7

答题要求: 您编写的代码需要符合CleanCode的要求(包括通用编码规范、安全编码规范和圈复杂度)
编码实现(java)

    public static void main(String[] args) {
        String expression1 = "9,3,5,-,2,*,+";
        int result1 = calcExpression(expression1);
        System.out.println(result1);
    }

    public static int calcExpression(String expression) {
        Stack<Integer> stack = new Stack<>();
        String[] elements = expression.split(",");
        for (String element : elements) {
            if (isOperator(element)) {
                int operand2 = stack.pop();
                int operand1 = stack.pop();
                int result = applyOperator(operand1, operand2, element);
                stack.push(result);
            } else {
                stack.push(Integer.parseInt(element));
            }
        }

        return stack.pop();
    }

    private static boolean isOperator(String element) {
        return "+".equals(element) || "-".equals(element) || "*".equals(element) || "/".equals(element);
    }

    private static int applyOperator(int operand1, int operand2, String operator) {
        switch (operator) {
            case "+":
                return operand1 + operand2;
            case "-":
                return operand1 - operand2;
            case "*":
                return operand1 * operand2;
            case "/":
                return operand1 / operand2;
            default:
                throw new IllegalArgumentException("Invalid operator: " + operator);
        }
    }

输出结果

5

Process finished with exit code 0
  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值