蓝桥杯 ALGO-156 表达式计算 JAVA代码 栈的应用
import java.util.Scanner;
import java.util.Stack;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
//1-2+3*(4-5)
while(in.hasNext()){
String str = in.next() ;
str="#"+str+"#" ;
//System.out.println(str);
Stack<Integer> ss = new Stack<Integer>() ;
Stack op = new Stack() ;
op.clear();
ss.clear();
for(int i=0;i<str.length();i++){
int pre = 0 ;
if(str.charAt(i)>='0'&&str.charAt(i)<='9'){///读到数字
pre = i ;
for(int j=i;j<str.length();j++){
if(str.charAt(j)<'0'||str.charAt(j)>'9'){
i=j ;
break ;
}
if(str.charAt(j)>='0'&&str.charAt(j)<='9'&&j==str.length()-1){
i=str.length() ;
break ;
}
}
//System.out.println(pre+","+i);
int x = Integer.valueOf(str.substring(pre, i)) ;
//System.out.println(x);
i--;
///压入数字栈
ss.push(x) ;
}else{//读到符号
if(str.charAt(i)=='('||(str.charAt(i)=='#'&&op.size()==0)){///左括号和标识直接进入符号栈
op.push(str.charAt(i)) ;
//System.out.println("begin");
continue ;
}
if((op.peek().equals('(')||op.peek().equals('#'))&&(str.charAt(i)=='+'||str.charAt(i)=='-'||str.charAt(i)=='*'||str.charAt(i)=='/')){//第一个运算符压入符号栈
op.push(str.charAt(i)) ;
//System.out.println("first");
continue ;
}
if(str.charAt(i)==')'){///右括号
int temp =0 ;
while(!op.peek().equals('(')){
int b = (int)ss.pop() ;
int a = (int)ss.pop() ;
if(op.peek().equals('+')){
temp = a+b;
}else if(op.peek().equals('-')){
temp = a-b;
}else if(op.peek().equals('*')){
temp = a*b;
}else {
temp = a/b;
}
op.pop();
ss.push(temp) ;
}
op.pop() ;
continue ;
}
if(str.charAt(i)=='#'){///结尾
int temp =0 ;
//System.out.println(op.peek());
while(!op.peek().equals('#')){
int b = (int)ss.pop() ;
int a = (int)ss.pop() ;
if(op.peek().equals('+')){
temp = a+b;
}else if(op.peek().equals('-')){
temp = a-b;
}else if(op.peek().equals('*')){
temp = a*b;
}else{
temp = a/b;
}
op.pop();
ss.push(temp) ;
}
op.pop() ;
continue ;
} ///+-同级之间相遇,前面的算一下就ok了
if((str.charAt(i)=='+'||str.charAt(i)=='-')&&(op.peek().equals('+')||op.peek().equals('-'))){
int temp=0;
int b = (int)ss.pop() ;
int a = (int)ss.pop() ;
if(op.peek().equals('+')){
temp = a+b;
}else{
temp = a-b;
}
//System.out.println("temp="+temp);
op.pop();
ss.push(temp) ;
op.push(str.charAt(i));
continue ;
}
/// */同级之间相遇
if((str.charAt(i)=='*'||str.charAt(i)=='/')&&(op.peek().equals('*')||op.peek().equals('/'))){
int temp=0;
int b = (int)ss.pop() ;
int a = (int)ss.pop() ;
if(op.peek().equals('*')){
temp = a*b;
}else{
temp = a/b;
}
op.pop();
ss.push(temp) ;
op.push(str.charAt(i));
continue ;
}
//+-遇到*/
if((str.charAt(i)=='+'||str.charAt(i)=='-')&&(op.peek().equals('*')||op.peek().equals('/'))){
int temp=0;
int b = (int)ss.pop() ;
int a = (int)ss.pop() ;
if(op.peek().equals('*')){
temp = a*b;
}else{
temp = a/b;
}
op.pop() ;
ss.push(temp) ;
op.push(str.charAt(i));
continue ;
}
///*/遇到+-
if((str.charAt(i)=='*'||str.charAt(i)=='/')&&(op.peek().equals('+')||op.peek().equals('-'))){
op.push(str.charAt(i));
continue ;
} }
}
System.out.println(ss.peek());
}
}
}
蓝桥杯 ALGO-156 表达式计算 JAVA代码 栈的应用的更多相关文章
- 蓝桥杯vip题阶乘计算
蓝桥杯vip题阶乘计算 详细题目 输入一个正整数n,输出n!的值. 其中n!=123*-*n. 算法描述 n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法.使用一个数组A来表示一个 ...
- 算法笔记_076:蓝桥杯练习 结点选择(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 有一棵 n 个节点的树,树上每个节点都有一个正整数权值.如果一个点被选择了,那么在树上和它相邻的点都不能被选择.求选出的点的权值和最大是多 ...
- 蓝桥杯 0/1背包问题 (java)
今天第一次接触了0/1背包问题,总结一下,方便以后修改.不对的地方还请大家不啬赐教! 上一个蓝桥杯的例题: 数据规模和约定 代码: import java.util.Scanner; public ...
- 算法笔记_083:蓝桥杯练习 合并石子(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 在一条直线上有n堆石子,每堆有一定的数量,每次可以将两堆相邻的石子合并,合并后放在两堆的中间位置,合并的费用为两堆石子的总数.求把所有石子 ...
- 算法笔记_064:蓝桥杯练习 操作格子(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 有n个格子,从左到右放成一排,编号为1-n. 共有m次操作,有3种操作类型: 1.修改一个格子的权值, 2.求连续一段格子权值和, 3.求 ...
- 表达式计算 java 后缀表达式
题目: 问题描述 输入一个只包含加减乖除和括号的合法表达式,求表达式的值.其中除表示整除. 输入格式 输入一行,包含一个表达式. 输出格式 输出这个表达式的值. 样例输入 1-2+3*(4-5) 样例 ...
- 蓝桥杯-加法变乘法(java)
蓝桥杯第六届省赛题目-加法变乘法(java) 题目: 我们都知道:1+2+3+ ... + 49 = 1225 现在要求你把其中两个不相邻的加号变成乘号,使得结果为2015 比如: 1+2+3+... ...
- 蓝桥杯-逆波兰表达式-java
/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...
- java实现第四届蓝桥杯逆波兰表达式
逆波兰表达式 正常的表达式称为中缀表达式,运算符在中间,主要是给人阅读的,机器求解并不方便. 例如:3 + 5 * (2 + 6) - 1 而且,常常需要用括号来改变运算次序. 相反,如果使用逆波兰表 ...
随机推荐
- 英雄联盟测试静态IP(固态IP)和动态IP的网速测试
在自己家里测试的,平时用迅雷下载大约600KB/S.同时,设置成动态IP的话,英雄联盟的延迟大约在100ms左右,如果设置成静态IP的话,大约是50ms左右,不过也有可能和DNS服务器的设置成静态有关 ...
- 阿里nacos k8s部署
阿里nacos k8s部署 [root@master1 nacos]# cat nacos-quick-start.yaml --- apiVersion: v1 kind: Service meta ...
- python signal模块
signal包负责在Python程序内部处理信号,典型的操作包括预设信号处理函数,暂 停并等待信号,以及定时发出SIGALRM等.要注意,signal包主要是针对UNIX平台(比如Linux, MAC ...
- 帮你培养类型思维TypeScript(一)
前言:作为一名程序员,相信你已经熟练掌握了JavaScript语言,由于其应用领域非常的广泛,所以算得上是每一个程序员必须要掌握的语言.但是JavaScript自身的缺点,相信每一个程序员也是深有体会 ...
- HTTP权威指南-URL与资源
URL与资源 URL是URI的子集 方案(http),主机(www.baidu.com),路径(/home/logo.png) 方案,其实有很多,HTTP.HTTPS.FTP,SMTP等等. http ...
- 安装AWX
1.安装最新版python 2.安装最新版docker 设置国内docker镜像源 curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | ...
- 022 Android .9图片的含义及制作教程
1.图片(.9.png格式)的概念 (1)9patch图片是andriod app开发里一种特殊的图片形式,文件的扩展名为:.9.png (2)9patch图片的作用就是在图片拉伸的时候保证其不会失真 ...
- [转帖]Nginx rewrite 规则 与 proxy_pass 实现
Nginx rewrite 规则 与 proxy_pass 实现 https://www.cnblogs.com/jicki/p/5546916.html Nginx rewrite 规则 与 pr ...
- [C++] 习题 2.15 实现简单环形队列
目录 前置技能 环形队列 具体实现 设计一个环形队列,用front和rear分别作为队头和队尾指针,另外用一个tag表示队列是空 ( 0 ) 还是不空 ( 1 ),这样就可以用front==rear作 ...
- Spyder中代码提示功能添加
问题描述:Spyder中编写python程序时,无函数智能提示.如想要输入np.reshape,无reshape提示 预期目标:输入 np. 然后智能提示reshape 解决方法: 第一步:进入本地 ...