『牛客|每日一题』逆波兰表达式

简介: 基础算法无论在研究生面试还是求职面试都是十分重要的一环,这里推荐一款算法面试神器:牛客网-面试神器;算法题只有多刷勤刷才能保持思路与手感,大家赶紧行动起来吧(温馨提示:常见的面试问答题库也很nice哦 https://www.nowcoder.com/link/pc_csdncpt_ll_sf

如果文章有帮到你的话记得点赞👍+收藏💗支持一下哦



1.每日一题

网络异常,图片无法展示
|

2.解题思路

2.1思路分析

计算逆波兰表达式:遇到数字就压栈,遇到运算符就弹出栈顶两个数进行计算,然后把计算结果压入栈中,直到栈中只剩下最后一个数,就是整个逆波兰表达式的计算结果。

  • step 1:引入辅助栈stk,遍历字符串,每次遇到数字就入栈,所以栈可以定义为Integer类型
  • step 2:当遇到"+","-","*","/"字符串的时候,则弹出栈顶两个数,进行相应的运算(先弹出来的是被操作数,后弹出来的是操作数;如减法时,是先弹出来的是被减数,后弹出来的是减数)
  • step 3:将计算结果(Integer类型)存入栈中
  • step 4:循环匹配字符串,直到所有字符串处理完成
  • step 5:栈中剩下的最后一个元素就是计算结果

2.2核心代码

importjava.util.*;

 

 

publicclassSolution {

   /**

    * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可

    * @param tokens string字符串一维数组

    * @return int整型

    */

   publicintevalRPN (String[] tokens) {

       // write code here

       Stack<Integer>stk=newStack<>();

       for(inti=0;i<tokens.length;++i){

           Strings=tokens[i];

           if(s.equals("+")||s.equals("-")||s.equals("*")||s.equals("/")){

               stk.push(cal(stk.pop(),s,stk.pop()));

           }else{

               stk.push(Integer.parseInt(s));

           }

       }

       returnstk.pop();

   }

   publicIntegercal(Integerb,Strings,Integera){

       switch(s){

           case"+":returna+b;

           case"-":returna-b;

           case"*":returna*b;

           case"/":returna/b;

       }

       return-1;

   }

}

网络异常,图片无法展示
|

📚订阅专栏:『牛客刷题集锦』

🍁每日推荐:基础算法无论在研究生面试还是求职面试都是十分重要的一环,这里推荐一款算法面试神器:牛客网-面试神器;算法题只有多刷勤刷才能保持思路与手感,大家赶紧行动起来吧(温馨提示:常见的面试问答题库也很nice哦)

如果文章有帮到你的话记得点赞👍+收藏💗支持一下哦


相关文章
|
8月前
|
Python
每日一题 1447. 最简分数
每日一题 1447. 最简分数
|
9月前
每日一题——移动零
每日一题——移动零
|
9月前
牛客网-重建二叉树
牛客网-重建二叉树
57 0
|
人工智能 BI
《蓝桥杯每日一题》并查集·AcWing1249. 亲戚
《蓝桥杯每日一题》并查集·AcWing1249. 亲戚
64 0
每日一题——后继者
每日一题——后继者
96 0
每日一题——后继者
|
C++
【寒假每日一题】AcWing 4728. 乘方
目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解
156 0
|
人工智能 算法 物联网
每日一题(day1)
每日一题(day1)
193 2
每日一题(day1)
|
人工智能 算法 物联网
每日一题(day5)
每日一题(day5)
176 1
每日一题(day5)
|
人工智能 算法 物联网
每日一题(day3)
每日一题(day3)
164 1
每日一题(day3)