java学习之—使用栈实现字符串数字四则运算
- /**
- * 使用栈存储后缀表达式
- * 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
java学习之—使用栈实现字符串数字四则运算的更多相关文章
- Java学习总结:飘逸的字符串
Java学习:飘逸的字符串 前言 相信不管我们运用Java语言来开发项目还是进行数据分析处理,都要运用到和字符串相关的处理方法.这个社会处处有着和字符串相关的影子:日志.文档.书籍等.既然我们离不开字 ...
- Java学习2_一些基础2_字符串_16.5.5
接上一次的博客. 不可变字符串: Java中String类没有提供用于修改字符串的方法.如果想将greeting中的“Hello”改为“Help!”需要先提取所需要的的字符,然后再拼接.即 greet ...
- java学习笔记(三)字符串
字符串String 创建方法: 一·通过new创建 String str1= new String("abc"); 二 直接创建 String str2="abc ...
- Java学习日记-3 Character和字符串
(先说几个小问题 1.在main方法中调用主类的其他方法时,必须先生成主类的对象 2.String s = new String("Hello") 生成了两个对象 3.熟用布尔+f ...
- Java学习笔记【五、字符串】
String类 11种构造,不一一列举 常用方法 s.length() 返回字符串长度 s1.contact(s2) 连接s1.s2 String.format("aaa %f bbb %d ...
- Java学习笔记【一、环境搭建】
今天把java的学习重新拾起来,一方面是因为公司的项目需要用到大数据方面的东西,需要用java做语言 另一方面是原先使用的C#公司也在慢慢替换为java,为了以后路宽一些吧,技多不压身 此次的学习目标 ...
- 【原】Java学习笔记022 - 字符串
package cn.temptation; public class Sample01 { public static void main(String[] args) { // 字符串 // 定义 ...
- Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录)
Java 打印金字塔 or 打印带数字的金字塔 (Java 学习中的小记录) 作者:王可利(Star·星星) 效果图: 代码如下: class Star8 { public static void m ...
- 《Java数据结构与算法》笔记-CH4-2用栈实现字符串反转
import java.io.BufferedReader; import java.io.InputStreamReader; //用栈来实现一个字符串逆序算法 /** * 数据结构:栈 */ cl ...
随机推荐
- UVA10603-Fill(BFS)
Problem UVA10603-Fill Accept:1162 Submit:10693 Time Limit: 3000 mSec Problem Description There are ...
- php 验证身份证号
function validation_filter_id_card($id_card){ if(strlen($id_card)==18){ return idcard_checksum18($id ...
- springboot RestTemplate请求
每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code 1.定义 RestTemplateConfig 配置类 @Configuratio ...
- 路飞学城-Python开发集训-第3章
学习心得: 通过这一章的作业,使我对正则表达式的使用直接提升了一个level,虽然作业完成的不怎么样,重复代码有点多,但是收获还是非常大的,有点找到写代码的感觉了,遗憾的是,这次作业交过,这次集训就结 ...
- (二 -3-3) 天猫精灵接入Home Assistant-自动发现Mqtt设备-自动生成配置信息
http://www.hassmart.com/products/switches/#tab=config switch: - platform: mqtt name: keting state_to ...
- 一步一步和我学Apache JMeter
一. Apache JMeter介绍 1. Apache JMeter是什么? Apache JMeter 是Apache组织的开放源代码项目,是一个100%纯Java桌面应用,用于压力测试和性能测量 ...
- 接口测试,获取登录后的cookies
参见: http://www.cnblogs.com/testwang/p/6023394.html
- C# — 动态获取本地IP地址及可用端口
1.在VS中动态获取本地IP地址,代码如下: 2.获取本机的可用端口以及已使用的端口:
- ASP.NET Core - 关于Tag Helper值得了解的五点
如果您开发过ASP.NET Core Web应用程序,您应该已经熟悉了Tag Helper.ASP.NET Core应用程序依赖Tag Helper来呈现表单和表单字段是很常见的.所以,一个视图通常包 ...
- Ubuntu脚本修改IP信息
#!/bin/bash cd /etc/network #清除4-9行 sed -i '4,9d' interfaces #在第3行添加网卡名称 sed -i "3a auto ${1}&q ...