蓝桥杯 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 而且,常常需要用括号来改变运算次序. 相反,如果使用逆波兰表 ...
随机推荐
- Js获取file上传控件的文件路径总结
总结一个获取file上传控件文件路径的方法 firefox由于保护机制只有文件名,不能获取完整路径. document.getElementById('file').onchange = functi ...
- 【嵌入式硬件Esp32】Eclipse c++切换回英文方法
1.英文版汉化为中文版时是通过:Help-Install New Soft,下载安装中文支持包,重启即可. 2.恢复回英文界面步骤则如下: 2.1.打开安装目录下的eclipse.ini,在文件文件中 ...
- Docker快速安装
目前装Docker得最简单方式就是脚本安装了,方法如下: curl -fsSL https://get.docker.com -o get-docker.sh sh get-docker.sh 安装后 ...
- SSH 连接时间超时
linux服务端 # vi /etc/ssh/sshd_config ClientAliveInterval 60 ClientAliveCountMax 3 # 注: # ClientAliveIn ...
- kafka原理分析
#kafka为什么有高吞吐量 1 由于接收数据时可以设置request.required.acks参数,一般设定为1或者0,即生产者发送消息0代表不关心kafka是否接收成功,也就是关闭ack:1代表 ...
- 031 Android 异步任务(AsyncTask)
1.介绍 AsyncTask(了解即可),重点掌握Handler+Thread 2.实现方法 3.执行步骤 4.java后台 package com.lucky.test36asynctask; im ...
- Ly与lyon的巅峰对决,描色法
http://paste.ubuntu.com/14124956/ #include <stdio.h> #include <stdlib.h> struct node { i ...
- Request部分知识点小结
HTTP: * 概念:Hyper Text Transfer Protocol 超文本传输协议 * 传输协议:定义了,客户端和服务器端通信时,发送数据的格式 * 特点: 1. 基于TCP/IP的高级协 ...
- Python25之字典1
一.字典的意义 字典不同于前述的序列类型,他是一种映射类型,它的引入就是为了简化定义索引值和元素值存在的特定关系的定义和访问问题 二,字典定义 字典变量名 = {key1 : value1, key2 ...
- vector 使用pair对
pair是一种序偶结构<x,y> 如果我们希望使用pair但又不需要map对其排序,可以在vector中使用pair对 插入pair对使用make_pair<typename,typ ...