韩顺平 数据结构与算法 (6)栈实现综合计算器

—————————>栈实现综合计算器<————————

思路分析
  1. 通过一个index值(索引),来遍历表达式
  2. 如果我们**发现是一个数字**,就直接**入数栈**
  3. 如果我们**发现是一个符号**,就分两种情况
     1. 符号栈**为空**,就直接入栈
     2. 符号栈**不空**,就进行比较—
        1. 如果**当前的操作符的优先级<=栈中的操作符**:就需要从数栈中pop出两个数,再从符号栈中pop出一个符号,进行运算,将结果入数栈,最后将当前的操作符入栈
        2. 如果**当前的操作符优先级>栈中的操作符**:直接将操作符入栈
  4. 当表达式扫描完毕,就顺序的从数栈和符号栈中pop出相应的数和符号并运算
  5. **最后数栈只有一个数字**

Ps:建立两个栈:数栈(numStack)和符号栈(operStack)

栈的功能: 栈顶(top)、最大值(maxSize)、数组(array)

​ 栈满(isFull)、栈空(isEmpty)、入栈(push)、出栈(pop)

​ 遍历(list)、定义符号优先级(priority)、判断数字或字符(isOper)、

​ 计算方法(cal)、查看符号栈顶(peek)

代码演示——栈实现综合计算机(中缀表达式)
package DataStructures.stack;

public class Calculator {
   
    public static void main(String[] args) {
   
        //输入表达式
        String expression = "7-2-2*5-1";
        //创建两个栈,数栈和符号栈
        ArrayStack2 numStack = new ArrayStack2(10);
        ArrayStack2 operStack = new ArrayStack2(10);
        //定义需要的相关变量
        int index = 0;//扫描
        int num1 = 0;
        int num2 = 0;
        int oper = 0;
        int res = 0;
        char ch = ' '; //将每次扫描得到的char保存到ch中
        String keepNum = "";//用于拼接多位数
        //开始while循环的扫描expression
        while (true) {
   
            //依次得到expression的每一个字符
            ch = expression.substring(index, index + 1).charAt(0);
            //判断ch是什么,然后做相应的处理
            if (operStack.isOper(ch)) {
   
                //如果是运算符
                //判断符号栈是否为空
                if (!operStack.isEmpty()) {
   
                    //不为空进行处理
                    //1. 如果当前的操作符的优先级<=栈中的操作符:就需要从数栈中pop出两个数,
                    //   再从符号栈中pop出一个符号,进行运算,将结果入数栈,最后将当前的操作符入栈
                    //2. 如果当前的操作符优先级>栈中的操作符:直接将操作符入栈
                    if (operStack.priority(ch) <= operStack.priority(operStack.peek())) {
   
                        //如果满足,就从数栈pop出两个数
                        num1 = numStack.pop();
                        num2 = numStack.pop();
                        oper = operStack.pop();
                        res = numStack.cal(num1, num2, oper);
                        //把运算结果入数栈
                        numStack.push(res);
                        //把运算符入符号栈
                        operStack.push(ch);
                    } else {
   
                        //如果符号>符号栈中的符号,直接输入
                        operStack.push(ch);
                    }
                } else {
   
                    //为空直接入符号栈
                    operStack.push(ch);
                }
            } else {
   
                //如果是数,则直接入数栈
                //将char变成int
                //numStack.push(ch - 48);
                //当处理多位数的时。不能发现是一个数就立刻入栈,因为可能是多位置数字
                //所以需要想expresssion的表达式的index后再看一位,如果是数就继续扫描,是符号就入栈
                //所以我们要定义一个字符串变量,用于拼接

                //处理多位数
                keepNum += ch;
                //如果ch已经是expression的最后一位,就直接入栈
                if (index == expression.length() - 1) {
   
                    numStack.push(Integer.parseInt(keepNum));
                } else {
   
                    //判断下一位是不是数字,如果是数字,就继续扫描,如果是运算符,就入栈
                    if (operStack.isOper(expression.substring(index + 1, index + 2).charAt(0))) {
   
                        //是操作符
                        numStack.push(Integer.parseInt(keepNum));
                        //还原keepNum
                        keepNum = "";
                    }
                }

            }
            //让index+1,并判断是否扫描到expression最后
            index++;
            if (index >= expression.length()) {
   
                break;
            }
        }

        //当表达式扫描完毕,就顺序的从数栈和符号栈中pop出相应的数和符号并运算
        while (true) {
   
            //如果符号栈为空,则计算到了最后的结果,数栈中只有一个数字
            if (operStack.isEmpty()) {
   
                break;
            }
            num1 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值