算法训练 表达式计算  
时间限制:1.0s   内存限制:256.0MB
    
问题描述
  输入一个只包含加减乖除和括号的合法表达式,求表达式的值。其中除表示整除。
输入格式
  输入一行,包含一个表达式。
输出格式
  输出这个表达式的值。
样例输入
1-2+3*(4-5)
样例输出
-4
数据规模和约定
  表达式长度不超过100,表达式运算合法且运算过程都在int内进行。
 
这题就是栈的应用的基础题目,虽然基础但是写起来还是挺麻烦的:
1,这题考察的是中缀表达式的计算,符号栈,数字栈,结合运算符的优先级就能写出来
2,具体运算流程课本上很详细。
3,模拟要细心一些
4,高级点的做法,结合编译原理或许代码量还能少很多。
 
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代码 栈的应用的更多相关文章

  1. 蓝桥杯vip题阶乘计算

    蓝桥杯vip题阶乘计算 详细题目 输入一个正整数n,输出n!的值. 其中n!=123*-*n. 算法描述 n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法.使用一个数组A来表示一个 ...

  2. 算法笔记_076:蓝桥杯练习 结点选择(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 有一棵 n 个节点的树,树上每个节点都有一个正整数权值.如果一个点被选择了,那么在树上和它相邻的点都不能被选择.求选出的点的权值和最大是多 ...

  3. 蓝桥杯 0/1背包问题 (java)

      今天第一次接触了0/1背包问题,总结一下,方便以后修改.不对的地方还请大家不啬赐教! 上一个蓝桥杯的例题: 数据规模和约定 代码: import java.util.Scanner; public ...

  4. 算法笔记_083:蓝桥杯练习 合并石子(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 在一条直线上有n堆石子,每堆有一定的数量,每次可以将两堆相邻的石子合并,合并后放在两堆的中间位置,合并的费用为两堆石子的总数.求把所有石子 ...

  5. 算法笔记_064:蓝桥杯练习 操作格子(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 有n个格子,从左到右放成一排,编号为1-n. 共有m次操作,有3种操作类型: 1.修改一个格子的权值, 2.求连续一段格子权值和, 3.求 ...

  6. 表达式计算 java 后缀表达式

    题目: 问题描述 输入一个只包含加减乖除和括号的合法表达式,求表达式的值.其中除表示整除. 输入格式 输入一行,包含一个表达式. 输出格式 输出这个表达式的值. 样例输入 1-2+3*(4-5) 样例 ...

  7. 蓝桥杯-加法变乘法(java)

    蓝桥杯第六届省赛题目-加法变乘法(java) 题目: 我们都知道:1+2+3+ ... + 49 = 1225 现在要求你把其中两个不相邻的加号变成乘号,使得结果为2015 比如: 1+2+3+... ...

  8. 蓝桥杯-逆波兰表达式-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  9. java实现第四届蓝桥杯逆波兰表达式

    逆波兰表达式 正常的表达式称为中缀表达式,运算符在中间,主要是给人阅读的,机器求解并不方便. 例如:3 + 5 * (2 + 6) - 1 而且,常常需要用括号来改变运算次序. 相反,如果使用逆波兰表 ...

随机推荐

  1. web端自动化——Selenium3+python自动化(3.7版本)-chrome67环境搭建

    前言 目前selenium版本已经升级到3.0了,网上的大部分教程是基于2.0写的,所以在学习前先要弄清楚版本号,这点非常重要.本系列依然以selenium3为基础. 一.selenium简介 Sel ...

  2. python:动态参数*args

    动态参数 顾名思义,动态参数就是传入的参数的个数是动态的,可以是1个.2个到任意个,还可以是0个.在不需要的时候,你完全可以忽略动态函数,不用给它传递任何值. Python的动态参数有两种,分别是*a ...

  3. python基础篇(一)

    PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...

  4. python format函数/print 函数详细讲解(4)

    在python开发过程中,print函数和format函数使用场景特别多,下面分别详细讲解两个函数的用法. 一.print函数 print翻译为中文指打印,在python中能直接输出到控制台,我们可以 ...

  5. redis 主从 哨兵

    数据库为什么要读写分离 写代码好多年了,大家先抛弃在代码框架里面各种花哨的设计之外,写的代码到最后无非就是为了增删查改数据库.一般项目数据库刚开始只是但一个库,随着数据量的增大,就开始优化数据库(抛开 ...

  6. lnmp二级域名配置相关

    阿里云那域名解析那有误读 我在偏远的电信网选择中国联通解析死活解析不出来 以上这么配置就对了....选择默认.瞬间解析出来.... 出于对nginx 配置不够熟悉 后来一点点理出来. 不带www 也正 ...

  7. 【坑】前后端分离开发中 跨域问题以及前台不带cookie的问题

    文章目录 前言 跨域问题 cookie问题 拦截器导致的跨域问题 后记 前言 场景一: 前台哒哒哒的点击页面,发送请求,但是后台服务器总是没有回应,后台接口虽打了断点,但是根本进不到断点处: 前端:我 ...

  8. hdu 5418 题解

    第一眼看到这题,哇,这不是我刚做完的题吗?大水题!然后 这题表面很水,实际上有点坑. 题意 求经过 $ 1 - n $(不能遗漏) 并且回到 $ 1 $ 的最短路. 在看这题之前我们可以来看下这题 最 ...

  9. stm32片上ADC转换实验

    原理图所示: BAT_DET 接到PB0 引脚,VSYS 是直流3.7V的电压.再来看下103的adc转换和引脚GPIO的关系 我们直接选用ADC1 根据上表格只能使用通道8 下面给我常用的ADC1寄 ...

  10. hadoop mapper reducer

    Local模式运行MR流程------------------------- 1.创建外部Job(mapreduce.Job),设置配置信息 2.通过jobsubmitter将job.xml + sp ...