栈的简单应用(利用Stack进行四则混合运算)(JAVA)

简介: 中缀表达式转后缀表达式图解,代码实现过程,完整代码,利用后缀表达式求值,完整代码

首先我们得先了解逆波兰表达式

中缀表达式转后缀表达式

所谓的中缀表达式其实就是我们平时写的例如:;而它的后缀表达式(也成为逆波兰表达式)

后缀表达式:指的是不包含括号运算符放在两个运算对象的后面,所有的计算按运算符出现的顺序,严格从左向右进行不再考虑运算符的优先规则)。

我们如果要利用程序来进行四则混合运算最重要的就是将输入的中缀表达式转后缀表达式

首先我们假设运算符中只有 加 减 乘 除 和 括号不然的话程序太复杂了。

图解

c2awgdfvou5n4_a4b2749a43604c78abbf12a146c03c79.png

代码实现过程:

首先我们先写一个方法 返回值是动态字符串数组(为了后面好计算),形参为字符串类型(因为输入值不只有数字还有运算符)。这里会用到栈所以也定义一个栈。

publicArrayList<String>midChangeEng(Stringstr) {
//这里用动态数组就不用担心不够用ArrayList<String>ret=newArrayList<String>();
Stack<Character>stack=newStack<>();
    }

image.gif

此时再创建一个新方法用来判断传入字符是不是运算符

publicbooleanisOperator(chars) {
if (s=='+'||s=='-'||s=='*'||s=='/'||s=='('||s==')') {
returntrue;
        }
returnfalse;
    }

image.gif

我们再利用运算符再ASCII码中的位置,创建一个数组用来表示它们的优先级

image.png

int[] able= {1,0,0,0,0,1};//分别代表 * + (null) - (null) / 的优先级

image.gif

利用循环遍历字符串

//遍历字符串for (inti=0; i<str.length(); i++) {
chara=str.charAt(i);
Stringtmp="";//用来暂时存储出栈的数字if (isOperator(a)) {
//是操作数            }else{
//如果是数字就放到ret中            }
        }
returnret;

image.gif

对操作数的操作 ,可是此段代码中重复代码过多,所以可以将其封装成一个方法。

if (isOperator(a)) {
//是操作数switch (a) {
case'+'://判断如果优先级不大于栈顶的元素那么就先出栈在入栈if(!stack.isEmpty()) {//出栈while(!stack.isEmpty() &&stack.peek() !='('&&able[(int)stack.peek() -42] >=able[(int)a-42]) {
Stringb="";
b+=stack.pop();
ret.add(b);
                            }
                        }
stack.push(a);
break;
case'-':
if(!stack.isEmpty()) {//出栈while(!stack.isEmpty() &&stack.peek() !='('&&able[(int)stack.peek() -42] >=able[(int)a-42]) {
Stringb="";
b+=stack.pop();
ret.add(b);
                            }
                        }
stack.push(a);
break;
case'*':
if(!stack.isEmpty()) {//出栈while(!stack.isEmpty() &&stack.peek() !='('&&able[(int)stack.peek() -42] >=able[(int)a-42]) {
Stringb="";
b+=stack.pop();
ret.add(b);
                            }
                        }
stack.push(a);
break;
case'/':
if(!stack.isEmpty()) {//出栈while(!stack.isEmpty() &&stack.peek() !='('&&able[(int)stack.peek() -42] >=able[(int)a-42]) {
Stringb="";
b+=stack.pop();
ret.add(b);
                            }
                        }
stack.push(a);
break;
case'(':
stack.push(a);
break;
case')':
while(!stack.isEmpty() &&stack.peek() !='(') {
Stringb="";
b+=stack.pop();
ret.add(b);
                        }
stack.pop();//删除‘(’break;
                }
            }

image.gif

如果是数字就进行以下操作

else{
//如果是数字就放到ret中Stringtmp="";
while(i<str.length() &&!isOperator(str.charAt(i))) {//数字有可能是多位的tmp+=str.charAt(i);
i++;
                }
i--;
ret.add(tmp);
            }

image.gif

再出函数之前要先将栈里面的全部导出来

//将栈里面剩余的全部出栈while(!stack.isEmpty()) {
Stringb="";
b+=stack.pop();
ret.add(b);
        }
returnret;

image.gif

完整代码:

publicstaticArrayList<String>midChangeEng(Stringstr) {
//这里用动态数组就不用担心不够用ArrayList<String>ret=newArrayList<String>();
Stack<Character>stack=newStack<>();
int[] able= {1,0,0,0,0,1};//分别代表 * + (null) - (null) / 的优先级//遍历字符串for (inti=0; i<str.length(); i++) {
chara=str.charAt(i);
if (isOperator(a)) {
//是操作数switch (a) {
case'+'://判断如果优先级不大于栈顶的元素那么就先出栈在入栈abcd(ret, stack, able, a);
break;
case'-':
abcd(ret, stack, able, a);
break;
case'*':
abcd(ret, stack, able, a);
break;
case'/':
abcd(ret, stack, able, a);
break;
case'(':
stack.push(a);
break;
case')':
while(!stack.isEmpty() &&stack.peek() !='(') {
Stringb="";
b+=stack.pop();
ret.add(b);
                        }
stack.pop();//删除‘(’break;
                }
            }else{
//如果是数字就放到ret中Stringtmp="";
while(i<str.length() &&!isOperator(str.charAt(i))) {//数字有可能是多位的tmp+=str.charAt(i);
i++;
                }
i--;
ret.add(tmp);
            }
        }
//将栈里面剩余的全部出栈while(!stack.isEmpty()) {
Stringb="";
b+=stack.pop();
ret.add(b);
        }
returnret;
    }

image.gif

image.png

利用后缀表达式求值:


这部分比较简单所以就直接展示了

image.png

完整代码:

publicintevalRPN(String[] tokens) {
Stack<Integer>stack=newStack<>();
for (inti=0; i<tokens.length; i++) {
if (isOperator(tokens[i])) {
intnum2=stack.pop();
intnum1=stack.pop();
switch(tokens[i].charAt(0)) {
case'+':
stack.push(num1+num2);
break;
case'-':
stack.push(num1-num2);
break;
case'*':
stack.push(num1*num2);
break;
case'/':
stack.push(num1/num2);
break;
                    }
                }else {
stack.push(Integer.parseInt(tokens[i]));
                }
            }
returnstack.pop();
        }
publicbooleanisOperator(Stringstr) {
if (str.length() !=1) {
returnfalse;
            }
if (str.charAt(0) =='+'||str.charAt(0) =='-'||str.charAt(0) =='*'||str.charAt(0) =='/') {
returntrue;
            }
returnfalse;
        }

image.gif


目录
相关文章
|
29天前
|
存储 数据采集 搜索推荐
Java 大视界 -- Java 大数据在智慧文旅旅游景区游客情感分析与服务改进中的应用实践(226)
本篇文章探讨了 Java 大数据在智慧文旅景区中的创新应用,重点分析了如何通过数据采集、情感分析与可视化等技术,挖掘游客情感需求,进而优化景区服务。文章结合实际案例,展示了 Java 在数据处理与智能推荐等方面的强大能力,为文旅行业的智慧化升级提供了可行路径。
Java 大视界 -- Java 大数据在智慧文旅旅游景区游客情感分析与服务改进中的应用实践(226)
|
30天前
|
机器学习/深度学习 数据采集 数据可视化
Java 大视界 -- 基于 Java 的大数据可视化在城市空气质量监测与污染溯源中的应用(216)
本文探讨Java大数据可视化在城市空气质量监测与污染溯源中的创新应用,结合多源数据采集、实时分析与GIS技术,助力环保决策,提升城市空气质量管理水平。
Java 大视界 -- 基于 Java 的大数据可视化在城市空气质量监测与污染溯源中的应用(216)
|
29天前
|
存储 监控 数据可视化
Java 大视界 -- 基于 Java 的大数据可视化在企业生产运营监控与决策支持中的应用(228)
本文探讨了基于 Java 的大数据可视化技术在企业生产运营监控与决策支持中的关键应用。面对数据爆炸、信息孤岛和实时性不足等挑战,Java 通过高效数据采集、清洗与可视化引擎,助力企业构建实时监控与智能决策系统,显著提升运营效率与竞争力。
|
29天前
|
Java 大数据 数据处理
Java 大视界 -- 基于 Java 的大数据实时数据处理在工业互联网设备协同制造中的应用与挑战(222)
本文探讨了基于 Java 的大数据实时数据处理在工业互联网设备协同制造中的应用与挑战。文章分析了传统制造模式的局限性,介绍了工业互联网带来的机遇,并结合实际案例展示了 Java 在多源数据采集、实时处理及设备协同优化中的关键技术应用。同时,也深入讨论了数据安全、技术架构等挑战及应对策略。
|
30天前
|
数据采集 搜索推荐 Java
Java 大视界 -- Java 大数据在智能教育虚拟学习环境构建与用户体验优化中的应用(221)
本文探讨 Java 大数据在智能教育虚拟学习环境中的应用,涵盖多源数据采集、个性化推荐、实时互动优化等核心技术,结合实际案例分析其在提升学习体验与教学质量中的成效,并展望未来发展方向与技术挑战。
|
29天前
|
机器学习/深度学习 人工智能 自然语言处理
Java 大视界 -- Java 大数据机器学习模型在自然语言生成中的可控性研究与应用(229)
本文深入探讨Java大数据与机器学习在自然语言生成(NLG)中的可控性研究,分析当前生成模型面临的“失控”挑战,如数据噪声、标注偏差及黑盒模型信任问题,提出Java技术在数据清洗、异构框架融合与生态工具链中的关键作用。通过条件注入、强化学习与模型融合等策略,实现文本生成的精准控制,并结合网易新闻与蚂蚁集团的实战案例,展示Java在提升生成效率与合规性方面的卓越能力,为金融、法律等强监管领域提供技术参考。
|
29天前
|
存储 人工智能 算法
Java 大视界 -- Java 大数据在智能医疗影像数据压缩与传输优化中的技术应用(227)
本文探讨 Java 大数据在智能医疗影像压缩与传输中的关键技术应用,分析其如何解决医疗影像数据存储、传输与压缩三大难题,并结合实际案例展示技术落地效果。
|
29天前
|
机器学习/深度学习 安全 Java
Java 大视界 -- Java 大数据在智能金融反洗钱监测与交易异常分析中的应用(224)
本文探讨 Java 大数据在智能金融反洗钱监测与交易异常分析中的应用,介绍其在数据处理、机器学习建模、实战案例及安全隐私等方面的技术方案与挑战,展现 Java 在金融风控中的强大能力。
|
29天前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据机器学习模型在生物信息学基因功能预测中的优化与应用(223)
本文探讨了Java大数据与机器学习模型在生物信息学中基因功能预测的优化与应用。通过高效的数据处理能力和智能算法,提升基因功能预测的准确性与效率,助力医学与农业发展。
|
30天前
|
机器学习/深度学习 搜索推荐 数据可视化
Java 大视界 -- Java 大数据机器学习模型在电商用户流失预测与留存策略制定中的应用(217)
本文探讨 Java 大数据与机器学习在电商用户流失预测与留存策略中的应用。通过构建高精度预测模型与动态分层策略,助力企业提前识别流失用户、精准触达,实现用户留存率与商业价值双提升,为电商应对用户流失提供技术新思路。