java 逆波兰表达式
最近想把这破机 装成WIN7 想想还是算了 ... 反正用的机会也不多。
不过 发现了一些 想念的东西
从前的作业.
从前的记忆.
package org.lmz; import java.util.Queue;
import java.util.Scanner;
import java.util.Stack;
import java.util.concurrent.LinkedBlockingQueue; public class calculator_test { static String operator = "+-*/%^()"; /**
* 预处理表达式,正、负号前加0(如果一个加号(减号)出现在最前面或左括号后面,则该加号(减号)为正负号) 比如 -1-(-1+1) 这种表达式 会处理成 0-1-(0-1+1)
*/
public static String pretreatment(String str) {
StringBuffer sb = new StringBuffer(str);
for (int i = 0; i < sb.length(); i++) {
char c = sb.charAt(i);
if (operator.indexOf(c) >= 0) {
if (i == 0) {
sb.insert(0, '0');
i++;
} else if (sb.charAt(i - 1) == '(') {
sb.insert(i, '0');
i++;
}
}
}
return sb.toString();
} /***
* 0 优先级相等 ; -1 op1 优先级大于op2; 1 op2 优先级大于 op1
*/
public static int opcompare(char op1, char op2) {
if (op1 == '(') { // 遇到括号 就直接入栈 所以 op2 大
return 1;
}
if ('^' == op1) {
if (op2 == '^') {
return 0;
}
return -1;
} else if ("+-".indexOf(op1) >= 0) {
if ("+-".indexOf(op2) >= 0) {
return 0;
}
return 1;
} else // if("*/%".indexOf(op1) >=0) 没必要 再判断是否为 */% 了
{
if ("+-".indexOf(op2) >= 0) {
return -1;
} else if ('^' == op2) {
return 1;
}
return 0;
}
}
/**
* 计算传入的算术表达式
*/
public static double Calculator2(String s) throws Exception {
//预处理式子
String prestr = pretreatment(s);
//用于保存 逆波兰式 的队列
LinkedBlockingQueue<String> polish = new LinkedBlockingQueue<String>();
// 拼接 数字 char ---> numble
StringBuffer temp = new StringBuffer(); Stack<Character> stack = new Stack<Character>();
for (int i = 0; i < prestr.length(); i++) { char c = prestr.charAt(i);
//如果找到 操作符
if (operator.indexOf(c) >= 0) {
if (temp.length() > 0) {//如果 有数字 就压栈
polish.offer(temp.toString());
temp = new StringBuffer();
}
switch (c) {
case '(':
stack.push(c);
break;
case ')':
while (stack.size() > 0) {
char op = stack.pop();
if (op != '(') {
polish.offer(String.valueOf(op));
} else {
break;
}
}
break;
default:
if (stack.size() == 0) {
stack.push(c);
} else {
while (stack.size() > 0) {
char op1 = stack.lastElement();
int com = opcompare(op1, c);
if (com <= 0) {
polish.offer(String.valueOf(stack.pop()));
} else {
stack.push(c);
break;
}
}
if (stack.size() == 0) {
stack.push(c);
}
}
break;
}
} else {
temp.append(c);
}
}
if (temp.length() > 0) {
polish.offer(temp.toString());
}
while (stack.size() > 0) {
polish.offer(String.valueOf(stack.pop()));
}
System.out.println("Calcstra Queue:" + polish.toString()); return CalcstraWithQueue(polish);
}
/**
* 计算 逆波兰表达式 用队列表示
* @throws Exception 各种错误都有可能
*/
public static double CalcstraWithQueue(Queue<String> que) throws Exception {
Stack<Double> stack = new Stack<Double>();
while(true)
{
String str = que.poll();
if(str == null)
{
break;
}
if (operator.indexOf(str) >= 0) { double num2 = stack.pop();
double num1 = stack.pop();
double tempresult = 0;
switch (str.charAt(0)) {
case '+':
tempresult = num1 + num2;
break;
case '-':
tempresult = num1 - num2;
break;
case '*':
tempresult = num1 * num2;
break;
case '/':
if(num2 == 0)
{
throw new Exception("出错:除数为 0");
}
tempresult = num1 / num2;
break;
case '%':
tempresult = num1 % num2;
break;
case '^':
tempresult = Math.pow(num1, num2);
break;
default:
throw new Exception("运算符: " + str + " 未识别!");
}
stack.push(tempresult);
} else {
stack.push(Double.valueOf(str));
}
}
return stack.pop();
}
public static void main(String[] args) { Scanner reader = new Scanner(System.in);
while(true)
{
String s = reader.nextLine();
double result = 0;
try {
result = Calculator2(s);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(result);
}
}
}
java 逆波兰表达式的更多相关文章
- 逆波兰表达式 java
描述 逆波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的逆波兰表示法为+ 2 3.逆波兰表达式的优点是运算符之间不必有优先级关系, 也不必用括号改变运算次序,例如(2 + 3) ...
- 逆波兰表达式求值 java实现代码
根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话说 ...
- 蓝桥杯-逆波兰表达式-java
/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...
- Java实现 LeetCode 150 逆波兰表达式求值
150. 逆波兰表达式求值 根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波 ...
- java实现第四届蓝桥杯逆波兰表达式
逆波兰表达式 正常的表达式称为中缀表达式,运算符在中间,主要是给人阅读的,机器求解并不方便. 例如:3 + 5 * (2 + 6) - 1 而且,常常需要用括号来改变运算次序. 相反,如果使用逆波兰表 ...
- lintcode 中等题:Evaluate Reverse Polish notation逆波兰表达式求值
题目 逆波兰表达式求值 在逆波兰表达法中,其有效的运算符号包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰计数表达. 样例 ["2", "1&q ...
- LeetCode:逆波兰表达式求值【150】
LeetCode:逆波兰表达式求值[150] 题目描述 根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除 ...
- 150 Evaluate Reverse Polish Notation 逆波兰表达式求值
求在 逆波兰表示法 中算术表达式的值.有效的运算符号包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰计数表达.例如: ["2", "1&quo ...
- leetcode算法学习----逆波兰表达式求值(后缀表达式)
下面题目是LeetCode算法:逆波兰表达式求值(java实现) 逆波兰表达式即后缀表达式. 题目: 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式.同 ...
随机推荐
- 探讨javascript面向对象编程
(个人blog迁移文章.) 前言: 下面将探讨javascript面向对象编程的知识. 请不要刻意把javascript想成面向对象编程是理所当然的. javascript里面,对象思想不可少,但是不 ...
- ORA-00265: instance recovery required, cannot set ARCHIVELOG mode
症状: 我打开后归档命令报告运行错误ORA-00265 SQL> alter database archivelog; alter database archivelog * ERROR at ...
- openwrt_git_pull命令提示merger冲突时如何解决?
直接贴代码 tf@ubuntu:~/projects/openwrt1407$ git pull Updating 331ecb0..d12dc6e error: Your local changes ...
- knob.js进度插件
关于knob.js进度插件的使用 关于这个插件,妹的,第一次使用坑死爹了,各种不会,幸亏我有持之以恒的精神,最终还是让其臣服于我的胯下.... 1. 引入 head 部分添加knob.js,同时引 ...
- valid number 判断字符串是否为有效数字
RT,面试题,给定一个字符串判断是否为科学计数法的有效数字.此题各种繁琐考虑.今天终于学会了用有限状态机来处理.理解之后简洁易懂.在此分享我的理解推导思路,大有收获啊. 网上有解法说先记录每个状态代表 ...
- 手机新闻网站,掌上移动新闻,手机报client,jQuery Mobile手机新闻网站,手机新闻网站demo,新闻阅读器开发
我们坐在地铁,经常来查看新浪手机新闻,腾讯新闻.或者刷微信看新闻更多功能.你有没有想过如何实现这些目标.移动互联网,更活泼. 因为HTML5到,jQuery Moblie到.今天我用jqm为了给你一个 ...
- CentOS 6.5玩转自制Linux、远程登录及Nginx安装测试
前言 系统定制在前面的博文中我们就有谈到过了,不过那个裁减制作有简单了点,只是能让系统跑起来而,没有太多的功能,也没的用户登录入口,而这里我们将详细 和深入的来谈谈Linux系统的详细定制过程和 ...
- Android Wear和二维码
这是一篇发布在Android官方开发者社区博客,15年年初的时候就看到了这篇文章,直到现在才有时间把它翻译下来. 这是一篇如何在Android Wear上面如何正确地展示二维码的文章,里面有许多的经验 ...
- ubuntu-使用终端配置网络
文件说明: IP.网关.掩码的配置文件:/etc/network/interfaces DNS配置文件:/etc/resolv.conf 配置步骤: 1)配置有关IP文件 配置IP.网关.掩码这些信息 ...
- 默认python2.6切换成python27
# 安装修改pythonyum -y install python27 python27-devel python -V; python2.6 -V # 查看当前python版本 这两个应该都 ...