JAVA 字符串的加减乘除 不包含括号

本文介绍了一个简单的Java程序,该程序能够解析并计算不含括号的四则运算表达式。通过将输入字符串转换为字符数组,程序识别运算符和操作数,并按优先级顺序执行乘除加减运算。
package com.lyjplus.app.modular.ceshi;

/**
 * @description:
 * @author: longyj
 * @create: 2020-04-21 21:14
 **/
public class Test {

    public static void main(String[] args) {
        /**
         * todo 此字符串为一个 四则运算表达是 不包含括号
         * todo 测试字符串 12+31 56*23 45+58-89 45+87-2*26 12+5*6/5-12
         */
        String str = "45+87-2*26/4";
        System.out.println(str + "=" + cal(str));
    }

    public static int cal(String str) {
        char[] temp   = str.toCharArray();
        int    len    = temp.length;
        char[] symbol = new char[len];
        int[]  value  = new int[len];
        int i = 0,j = 0;

        for (int k = 0; k < temp.length; k++) {
            if (isSymbol(temp[k])) {//是符号
                symbol[i++] = temp[k];
            } else {//不是符号
                StringBuffer buffer = new StringBuffer();
                while (k < temp.length && !isSymbol(temp[k])) {
                    buffer.append(temp[k]);
                    k++;
                }
                value[j++] = Integer.parseInt(new String(buffer));
                k--;
            }
        }
        i--;
        j--;
        for (int f_i = 0; f_i <= i; f_i++) {//遍历符号,先进行*和/的运算
            if (symbol[f_i] == '*') {
                value[f_i + 1] = value[f_i] * value[f_i + 1];
                value[f_i] = Integer.MAX_VALUE;
            } else if (symbol[f_i] == '/') {
                value[f_i + 1] = value[f_i] / value[f_i + 1];
                value[f_i] = Integer.MAX_VALUE;
            }
        }

        int up_i = 0, up_j = 0;
        char[] up_symbol = new char[i + 1];
        int[] up_value = new int[j + 1];
        for (int p = 0; p <= i; p++) {
            if (symbol[p] != '#')
                up_symbol[up_i++] = symbol[p];
        }
        for (int p = 0; p <= j; p++) {
            if (value[p] != Integer.MAX_VALUE)
                up_value[up_j++] = value[p];
        }
        //索引边界
        up_i--;up_j--;

        //后进行+和-的运算
        for (int y_i = 0; y_i <= up_i; y_i++)//遍历符号表
        {
            if (up_symbol[y_i] == '+') {
                up_value[y_i + 1] = up_value[y_i] + up_value[y_i + 1];
            } else if (up_symbol[y_i] == '-') {
                up_value[y_i + 1] = up_value[y_i] - up_value[y_i + 1];
            }
        }
        return up_value[up_j];
    }

    public static boolean isSymbol(char s) {
        if (s == '+' || s == '-' || s == '*' || s == '/')
            return true;
        else
            return false;
    }
}
Java中实现一个简单的括号加减乘除混合运算的计算器,可以使用栈(Stack)数据结构来存储操作数运算符,遵循"左到右"的原则处理运算。这里是一个基础的解决方案: ```java import java.util.Stack; public class SimpleCalculator { public static double calculate(String expression) { Stack<Double> operands = new Stack<>(); Stack<Character> operators = new Stack<>(); for (int i = 0; i < expression.length(); i++) { char ch = expression.charAt(i); // 如果是数字,直接压入操作数栈 if (Character.isDigit(ch)) { double num = 0; while (i < expression.length() && Character.isDigit(expression.charAt(i))) { num = num * 10 + (expression.charAt(i) - '0'); i++; } i--; operands.push(num); } else if (ch == '+' || ch == '-' || ch == '*' || ch == '/') { // 运算符 // 先处理完前一个运算 while (!operators.isEmpty() && hasPrecedence(ch, operators.peek())) { double rightOp = operands.pop(); double leftOp = operands.pop(); char op = operators.pop(); switch (op) { case '+': operands.push(leftOp + rightOp); break; case '-': operands.push(leftOp - rightOp); break; case '*': operands.push(leftOp * rightOp); break; case '/': operands.push(leftOp / rightOp); break; } } operators.push(ch); } } // 最后处理剩余的运算 while (!operators.isEmpty()) { double rightOp = operands.pop(); double leftOp = operands.pop(); char op = operators.pop(); switch (op) { case '+': operands.push(leftOp + rightOp); break; case '-': operands.push(leftOp - rightOp); break; case '*': operands.push(leftOp * rightOp); break; case '/': operands.push(leftOp / rightOp); break; } } return operands.pop(); // 返回最终结果 } private static boolean hasPrecedence(char op1, char op2) { return (op2 == '(' || (op1 == '*' && op2 != '/') || (op1 == '/' && op2 != '*')); } public static void main(String[] args) { System.out.println(calculate("2+3*4")); // 输出:14 } } ``` 在这个示例中,我们遍历输入的字符串,每当遇到数字就推入操作数栈,遇到运算符则根据优先级规则逐步弹出并处理栈顶的操作数。注意这里假设了除数会为零。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值