java学习之—使用栈实现字符串数字四则运算

Wesley13
• 阅读 730
/**
 * 使用栈存储后缀表达式
 * Create by Administrator
 * 2018/6/13 0013
 * 下午 2:25
 **/
public class StackX {

    private int maxSize;
    private char[] stackArray;
    private int top;

    public StackX(int size)      // 构造函数
    {
        maxSize = size;
        stackArray = new char[maxSize];
        top = -1;
    }

    public void push(char j)     // 将项目放在堆栈的顶部
    {
        stackArray[++top] = j;
    }

    public char pop()            // 从堆栈顶部取项
    {
        return stackArray[top--];
    }

    public char peek()           // 从堆栈顶部查看
    {
        return stackArray[top];
    }

    public boolean isEmpty()    // 如果栈为空,则为true
    {
        return (top == -1);
    }

    public boolean isFull()     // 如果堆栈已满 true
    {
        return (top == maxSize - 1);
    }

    public int size()           // return size
    {
        return top + 1;
    }

    public char peekN(int n)     // peek at index n
    {
        return stackArray[n];
    }

    public void displayStack(String s) {
        System.out.print(s);
        System.out.print("Stack (bottom-->top): ");
        for (int j = 0; j < size(); j++) {
            System.out.print(peekN(j));
            System.out.print(' ');
        }
        System.out.println("");
    }

}

/**
 * 使用栈存储计算过程结果
 * Create by Administrator
 * 2018/6/14 0014
 * 上午 10:37
 **/
public class StackR {
    private int maxSize;
    private int[] stackArray;
    private int top;

    public StackR(int size)      // 构造函数
    {
        maxSize = size;
        stackArray = new int[maxSize];
        top = -1;
    }

    public void push(int j)     // 将项目放在堆栈的顶部
    {
        stackArray[++top] = j;
    }

    public int pop()            // 从堆栈顶部取项
    {
        return stackArray[top--];
    }

    public int peek()           // 从堆栈顶部查看
    {
        return stackArray[top];
    }

    public boolean isEmpty()    // 如果栈为空,则为true
    {
        return (top == -1);
    }

    public boolean isFull()     // 如果堆栈已满 true
    {
        return (top == maxSize - 1);
    }

    public int size()           // return size
    {
        return top + 1;
    }

    public int peekN(int n)     // peek at index n
    {
        return stackArray[n];
    }

    public void displayStack(String s) {
        System.out.print(s);
        System.out.print("Stack (bottom-->top): ");
        for (int j = 0; j < size(); j++) {
            System.out.print(peekN(j));
            System.out.print(' ');
        }
        System.out.println("");
    }
}

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * Create by Administrator
 * 2018/6/13 0013
 * 下午 2:38
 **/
public class InTOPost {

    private StackX stackX;
    private StackR stackR;
    private String input;
    private String outPut = "";

    public InTOPost(String in) {
        this.input = in;
        int stackSize = input.length();
        stackX = new StackX(stackSize);

    }

    /**
     * 中缀表达式转后缀表达式
     * @return
     */
    public String doTrans() {
        for (int i = 0; i < input.length(); i++) {
            char ch = input.charAt(i);//拿到每个字符
            stackX.displayStack("For " + ch + " ");
            switch (ch) {
                case '+':
                case '-':
                    getOpera(ch, 1);
                    break;
                case '*':
                case '/':
                    getOpera(ch, 2);
                    break;
                case ')':
                    getParen(ch);
                    break;
                case '(':
                    stackX.push(ch);
                    break;
                default:
                    outPut = outPut + ch;           //是数字将其写入输出
                    break;
            }
        }
        while (!stackX.isEmpty()) {
            stackX.displayStack("While ");
            outPut = outPut + stackX.pop();
        }
        stackX.displayStack("End ");
        return outPut;
    }

    private void getOpera(char opThis, int prec1) {
        while (!stackX.isEmpty()) {
            char opTop = stackX.pop();
            if (opTop == '(') {
                stackX.push(opTop);
                break;
            } else {
                int prec2;
                if (opTop == '+' || opTop == '-') {
                    prec2 = 1;
                } else {
                    prec2 = 2;
                }
                if (prec2 < prec1) {
                    stackX.push(opTop);
                    break;
                } else {
                    outPut = outPut + opTop;
                }
            }
        }
        stackX.push(opThis);
    }

    private void getParen(char ch) {
        while (!stackX.isEmpty()) {
            char chx = stackX.pop();
            if (chx == '(') {
                break;
            } else {
                outPut = outPut + chx;
            }
        }
    }

    /**
     * 计算后缀表达式的结果
     * @param output
     * @return
     */
    public int doParse(String output) {
        stackR = new StackR(20);            //新建堆栈
        char ch;
        int num1, num2, interAns;
        for (int i = 0; i < output.length(); i++) { //遍历后缀表达式的字符串
            ch = output.charAt(i);               // 读取到每一个字符
            stackR.displayStack(ch + " ");
            if (ch >= '0' && ch <= '9') {        // 判断是不是数字
                stackR.push((int) (ch - '0'));   // 放入到栈里
            } else {
                num2 = stackR.pop();             // 如果不是数字,就从栈里取出两个数字
                num1 = stackR.pop();
                switch (ch) {                   // 判断是哪个运算符,并计算
                    case '+':
                        interAns = num1 + num2;
                        break;
                    case '-':
                        interAns = num1 - num2;
                        break;
                    case '*':
                        interAns = num1 * num2;
                        break;
                    case '/':
                        interAns = num1 / num2;
                        break;
                    default:
                        interAns = 0;
                }
                stackR.push(interAns);      // 把计算结果放入栈里
            }
        }
        interAns = stackR.pop();           // 获得最终结果
        return interAns;
    }

    /**
     * 获取用户输入
     * @return
     * @throws IOException
     */
    public static String getString() throws IOException {
        InputStreamReader isr = new InputStreamReader(System.in);
        BufferedReader br = new BufferedReader(isr);
        String s = br.readLine();
        return s;
    }

    public static void main(String[] args) throws IOException {
        String input, output;
        while (true) {
            System.out.print("Enter infix: ");
            System.out.flush();
            input = getString();
            if (input.equals("")) {
                break;
            }
            InTOPost toPost = new InTOPost(input);
            output = toPost.doTrans();
            System.out.println("Postfix is " + output + "\n");
            int result = toPost.doParse(output);
            System.out.println("结果:" + result);
        }
    }

  运行测试:

请输入:  (4+2*3)/2

For ( Stack (bottom-->top):
For 4 Stack (bottom-->top): (
For + Stack (bottom-->top): (
For 2 Stack (bottom-->top): ( +
For * Stack (bottom-->top): ( +
For 3 Stack (bottom-->top): ( + *
For ) Stack (bottom-->top): ( + *
For / Stack (bottom-->top):
For 2 Stack (bottom-->top): /
While Stack (bottom-->top): /
End Stack (bottom-->top):
Postfix is 423*+2/

4 Stack (bottom-->top):
2 Stack (bottom-->top): 4
3 Stack (bottom-->top): 4 2
* Stack (bottom-->top): 4 2 3
+ Stack (bottom-->top): 4 6
2 Stack (bottom-->top): 10
/ Stack (bottom-->top): 10 2
结果:5

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
Java爬虫之JSoup使用教程
title:Java爬虫之JSoup使用教程date:201812248:00:000800update:201812248:00:000800author:mecover:https://imgblog.csdnimg.cn/20181224144920712(https://www.oschin
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这