感谢这位原文网友,原文来自http://blog.csdn.net/yunxiang/article/details/1918717
代码不多只有三个类,第一个是对象类,第二个是解析类(主类,外面就用这个类的接口),第三个是计算类
package expression1;
import java.util.*;
//栈类
public class Stacks {
private LinkedList list = new LinkedList();
int top = -1;
public void push(Object value) {
top++;
list.addFirst(value);
}
public Object pop() {
Object temp = list.getFirst();
top--;
list.removeFirst();
return temp;
}
public Object top() {
return list.getFirst();
}
}
第二个是解析类(主类,外面就用这个类的接口)
package expression1;
import java.io.*;
import java.util.*;
public class Expression {
private ArrayList expression = new ArrayList();// 存储中序表达式
private ArrayList right = new ArrayList();// 存储右序表达式
private String result;// 结果
// 依据输入信息创建对象,将数值与操作符放入ArrayList中
private Expression(String input) {
StringTokenizer st = new StringTokenizer(input, "+-*/()", true);
while (st.hasMoreElements()) {
String s = st.nextToken();
expression.add(s);
}
}
// 将中序表达式转换为右序表达式
private void toRight() {
Stacks aStack = new Stacks();
String operator;
int position = 0;
while (true) {
if (Calculate.isOperator((String) expression.get(position))) {
if (aStack.top == -1 || ((String) expression.get(position)).equals("(")) {
aStack.push(expression.get(position));
} else {
if (((String) expression.get(position)).equals(")")) {
while (true) {
if (aStack.top != -1 && !((String) aStack.top()).equals("(")) {
operator = (String) aStack.pop();
right.add(operator);
} else {
if (aStack.top != -1)
aStack.pop();
break;
}
}
} else {
while (true) {
if (aStack.top != -1
&& Calculate.priority((String) expression.get(position)) <= Calculate
.priority((String) aStack.top())) {
operator = (String) aStack.pop();
if (!operator.equals("("))
right.add(operator);
} else {
break;
}
}
aStack.push(expression.get(position));
}
}
} else
right.add(expression.get(position));
position++;
if (position >= expression.size())
break;
}
while (aStack.top != -1) {
operator = (String) aStack.pop();
if (!operator.equals("("))
right.add(operator);
}
}
// 对右序表达式进行求值
private void getResult() {
this.toRight();
for (int i = 0; i < right.size(); i++) {
System.out.println(right.get(i));
}
Stacks aStack = new Stacks();
String op1, op2, is = null;
Iterator it = right.iterator();
while (it.hasNext()) {
is = (String) it.next();
if (Calculate.isOperator(is)) {
op1 = (String) aStack.pop();
op2 = (String) aStack.pop();
aStack.push(Calculate.twoResult(is, op1, op2));
} else
aStack.push(is);
}
result = (String) aStack.pop();
it = expression.iterator();
while (it.hasNext()) {
System.out.print((String) it.next());
}
System.out.println("=" + result);
}
public static void main(String avg[]) {
try {
System.out.println("Input a expression:");
BufferedReader is = new BufferedReader(new InputStreamReader(System.in));
for (;;) {
String input = new String();
input = is.readLine().trim();
if (input.equals("q"))
break;
else {
Expression boya = new Expression(input);
boya.getResult();
}
System.out.println("Input another expression or input 'q' to quit:");
}
is.close();
} catch (IOException e) {
System.out.println("Wrong input!!!");
}
}
}
第三个是计算类
package expression1;
public class Calculate {
// 判断是否为操作符号
public static boolean isOperator(String operator) {
if (operator.equals("+") || operator.equals("-") || operator.equals("*") || operator.equals("/")
|| operator.equals("(") || operator.equals(")"))
return true;
else
return false;
}
// 设置操作符号的优先级别
public static int priority(String operator) {
if (operator.equals("+") || operator.equals("-"))
return 1;
else if (operator.equals("*") || operator.equals("/"))
return 2;
else
return 0;
}
// 做2值之间的计算
public static String twoResult(String operator, String a, String b) {
try {
String op = operator;
String rs = new String();
double x = Double.parseDouble(b);
double y = Double.parseDouble(a);
double z = 0;
if (op.equals("+"))
z = x + y;
else if (op.equals("-"))
z = x - y;
else if (op.equals("*"))
z = x * y;
else if (op.equals("/"))
z = x / y;
else
z = 0;
return rs + z;
} catch (NumberFormatException e) {
System.out.println("input has something wrong!");
return "Error";
}
}
}
分享到:
相关推荐
1.本例是对数据结构栈的练习 2.本例使用了java类集作为辅助,但不是必要,所有功能都可以自己实现 3.本例有输入四则运算的合法性判断方法,是基于逻辑实现,可以使用正则表达式字符匹配,会是代码简洁不少.
逆波兰式 java编写,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
编译原理逆波兰式源代码,下载就能打开,打开.dsw文件。基于c++
本人的编程能力不是很强 大三用java编写的逆波兰式计算器 费了一些牛劲儿 可以实现一定的负数和减号的区别,但是有一种-(A+B)的功能不能实现 希望哪个编程高手能完善一下
将一个普通的中序表达式转换为逆波兰表达式的一般算法是: 1)首先构造一个运算符栈,此运算符在栈内遵循越往栈顶优先级越高的原则。 (2)读入一个用中缀表示的简单算术表达式,为方便起见,设该简单算术表达式的...
逆波兰算法的java版,能够将运算字符串转换为逆波兰式,并尽心简单的错误判断处理!
课程作业,使用逆波兰式算法,使用MFC
计算器实现了基本的运算功能,可做表达式计算,以逆波兰式运算
java 逆波兰式 (这个是java版的 还附有实验报告)
C语言逆波兰式(数据结构),用vc写的,可以试试
通过把输入的中缀表达示转换为逆波兰式实现整数及小数的四则运算,为了简便,这个程序只支持小括号,中括号和大括号暂不支持,需要的话自己插入几句代码就行了。 gcc下编译通过,没在window下测试。
工具提供四则运算解析功能。将.hpp文件引入C++工程中即可使用。详情用法参见文件中注释
编译原理中的中间语言翻译器的构造所使用的将一个表达式转换为逆波兰式的算法实现,我用的是vc++6.0写的,程序挺简单的
3.设计出模块结构、测试数据,初步编制好程序 2.如果遇到错误的表达式,应输出错误提示信息(该信息越详细越好) 3.对学有余力的同学,测试用的表达式事先放在文本
一个用从语言来实现的算法实例,模拟计算机的混合运算机制
这是严蔚敏《数据结构》配套习题册上的题目:将逆波兰式转换成波兰式,并提示错误(作为简化,只处理"+-*/"和0~9的数字)。 例如:"123*-"转换成波兰式为"-1*23" 逆波兰式"123*-"的表达式树如下: 所以这个转换...
JAVA版的逆波兰式
逆波兰式的递归实现(c++),其实这个很接近一个完整的计算器了,有兴趣的可以继续扩展功能
逆波兰式是编译原理中的重点知识。 利用逆波兰式生成算法编写程序,将从键盘上输入的算法表达式(中缀表达式)转化成逆波兰式。 这个是C++版的逆波兰式
编译原理逆波兰式编译原理逆波兰式编译原理逆波兰式编译原理逆波兰式 用vc++写的,含有幂次运算符