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 ...
随机推荐
- 转://Oracle 单引号转义
在ORACLE中,单引号有两个作用: 1:字符串是由单引号引用 2:转义. 单引号的使用是就近配对,即就近原则.而在单引号充当转义角色时相对不好理解 1.从第二个单引号开始被视为转义符,如果第二个单引 ...
- 小a的排列
链接:https://ac.nowcoder.com/acm/contest/317/G来源:牛客网 小a有一个长度为nn的排列.定义一段区间是"萌"的,当且仅当把区间中各个数排序 ...
- Linux 系统安装
内容概要 VMware虚拟机软件应用 Linux系统安装设置 远程登录管理工具介绍 VMware 简介 VMware是一个虚拟PC的软件,可以在现有的操 作系统上虚拟出一个新的硬件 ...
- Emacs 中使用中文插件 eim
在 Emacs 中输入中文,一般用 ibus 一类的输入法也能应付,但来回切换有点麻烦,这里介绍国人写的一个好插件 eim. - 安装 由于在 list-packages 中没有找到这个插件,所以不能 ...
- burnside+polya 整理
先定义几个含义和符号:起始状态/方法/位置/元素/:以染色为例,起始状态是所有的染色方案,方法是以起始状态所有染色方案为基准转变为新的染色情景的操作(如旋转),位置则必须是没有任何染色效果的抽象空间, ...
- centos 7 安装mqtt 修改用户名和密码
我先新买个Centos 的系统 咱登录呢就用这个软件,主要是方便,可以少安装一些东西 根据自己的系统选择,上面的是32位的. 输入 root 回车 输入密码然后回车 输入的时候什么也不显示 输入 c ...
- face detection[FaceBoxes]
该文来自<FaceBoxes: A CPU Real-time Face Detector with High Accuracy>.该文时间线是2018年1月 虽然人脸检测上随着深度学习的 ...
- Intellij Idea 2017创建web项目及tomcat部署实战
相关软件:Intellij Idea2017.jdk16.tomcat7 Intellij Idea直接安装(可根据需要选择自己设置的安装目录),jdk使用1.6/1.7/1.8都可以,主要是配置好系 ...
- Vue-computed的set和get
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- javaweb 项目启动问题:Application Server was not connected before run configuration stop, reason: javax.manage
参考:https://blog.csdn.net/whm18322394724/article/details/80290187 换成本机的jre就行了(路径要正确,特别是项目迁移的时候有时候用环境变 ...