java实现输入公式后自动计算_输入运算公式 得到结果 java输入一个字符串,包含数字和加(+)、减(-)、乘(*)、除(/)等四则运算符号,要求输出其计算结果.如12*2+3-4,输出23.我是j...

这篇博客介绍了如何利用栈数据结构将中缀表达式转化为后缀表达式,并详细解释了计算后缀表达式值的过程。通过Java代码展示了具体的实现,包括词法分析、中缀转后缀以及后缀表达式的计算。文章适合对算法和数据结构感兴趣的读者,尤其是学习计算理论和编译原理的同学。
摘要由CSDN通过智能技术生成

7d14a2b81882cfe4494b096a84150b2a.png 优质解答

通过栈实现,先用栈将中缀表达式转化为后缀表达式,然后再用栈计算后缀表达式的值的

package com.saturday;

import java.text.NumberFormat;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import java.util.Stack;

import java.util.regex.Matcher;

import java.util.regex.Pattern;

public class MyParse {

static Map optrOrder;

static {

optrOrder=new HashMap();

optrOrder.put("(",0);

optrOrder.put("*",1);

optrOrder.put("/",1);

optrOrder.put("%",1);

optrOrder.put("+",2);

optrOrder.put("-",2);

optrOrder.put("^",3);

optrOrder.put("#",3);

}

public static void main(String[] args){

List tokens;

try{

//词法分析

tokens=lex("+2* (-2+3*4)+-5");

//中缀转后缀

tokens=toRpn(tokens);

//计算结果

System.out.println(calcRpn(tokens));

}catch(Exception ex){

ex.printStackTrace();

}

}

/**

* 将输入串转换为操作符串

* @param sExpres

* @return

*/

public static List lex(String sExpres){

List tokens=new ArrayList();

//将表达式分割成符号序列

String sRegExp="(((?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值