当前位置:   article > 正文

代码随想录算法训练营第十天|LeetCode 20, 1047, 150

代码随想录算法训练营第十天|LeetCode 20, 1047, 150

目录

LeetCode 20. 有效的括号 

LeetCode 1047. 删除字符串中的所有相邻重复项 

LeetCode  150. 逆波兰表达式求值 


LeetCode 20. 有效的括号 

文章讲解: 代码随想录

思路分析:
有三种情况是不匹配的,第一种就是左边多一个或多个字符;第二种就是右边多一个或多个字符;最后一种情况就是类型不匹配。其次,当遇到左符号的时候,添加右符号进入队列。在循环中,当队列为空的时候,就证明了多了一个或多个右符号。跳出循环后,还要再次检测队列是否为空,不为空就证明了多一个或多个左符号。首先要有这个概念,然后写代码就会好写很多。
代码如下(Java):
  1. class Solution {
  2. public boolean isValid(String s) {
  3. //定义一个栈对象
  4. Deque<Character> deque = new LinkedList<>();
  5. //定义字符character接收字符s的每一个字符
  6. char character;
  7. //遍历字符串s
  8. for(int i = 0; i < s.length(); i++){
  9. character = s.charAt(i);
  10. //如果是左符号,push右符号进入栈,为后续出栈寻找相同字符做准备
  11. if(character == '('){
  12. deque.push(')');
  13. }else if(character == '['){
  14. deque.push(']');
  15. }else if(character == '{'){
  16. deque.push('}');
  17. }else if(deque.isEmpty() || deque.peek() != character){ //这里两种情况不匹配,一种就是右符号多一个或几个,另一种就是符号类型不匹配
  18. return false;
  19. }else{ //相同元素就pop出去
  20. deque.pop();
  21. }
  22. }
  23. //循环结束之后,看一看栈里面还有没有元素
  24. //还有元素,就是左符号多一个或几个
  25. //没有元素,就证明左右符号匹配成功
  26. return deque.isEmpty();
  27. }
  28. }
总结:虽然是LeetCode 的简单题,但是对代码的实践能力,还有对题目的分析也有一定的要求。上述题目中,我们需要分析出有三种条件是不符合题目的,然后根据这三种情况开始构想代码,先思考后写代码我觉得也蛮重要的。

LeetCode 1047. 删除字符串中的所有相邻重复项 

文章讲解: 代码随想录

思路分析:

遍历字符串S,首先把字符串S的字符push到栈中,在push的过程中,你要判断栈中是否已经有相同的元素,如果有相同元素则把这个元素pop出去,否则就继续push栈中。

代码如下(Java):

  1. class Solution {
  2. public String removeDuplicates(String s) {
  3. ArrayDeque<Character> deque = new ArrayDeque<>();
  4. char ch;
  5. //遍历字符串s
  6. for(int i = 0; i < s.length(); i++){
  7. ch = s.charAt(i);
  8. //push元素的时候,需要注意两种情况
  9. //一种是:当栈里面为空的时候也可以push元素
  10. //另一种则是:push的时候栈的顶部没有当前准备push的元素
  11. //判断的时候还要注意这两种判断条件的顺序问题
  12. if(deque.isEmpty() || deque.peek() != ch){
  13. deque.push(ch);
  14. }else{
  15. deque.pop();
  16. }
  17. }
  18. String str = "";
  19. //由于出栈的时候与要的结果是相反顺序的,所以要进行处理一下
  20. while(!deque.isEmpty()){
  21. str = deque.pop() + str;
  22. }
  23. return str;
  24. }
  25. }

总结:这题可以熟悉一下栈的操作,加强对栈的理解。


 

 思路分析:

当遇到数字的时候,就把数字进行入栈;当遇到符号的时候,就在栈pop两个元素出来。

代码如下(Java):

  1. class Solution {
  2. public int evalRPN(String[] tokens) {
  3. Deque<Integer> stack = new LinkedList();
  4. //遍历字符串数组tokens,并把值赋给s
  5. for(String s : tokens){
  6. //逐个匹配并进行相应的操作
  7. if("+".equal(s)){
  8. stack.push(stack.pop() + stack.pop());
  9. }else if("-".equals(s)){
  10. stack.push(-stack.pop() + stack.pop());
  11. }else if("*".euqals(s)){
  12. stack.push(stack.pop() * stack.pop());
  13. }else if("/".euqals(s)){
  14. int temp1 = stack.pop();
  15. int temp2 = stack.pop();
  16. stack.push(temp2 / temp1);
  17. }else{
  18. stack.push(Integer.valueOf(s));
  19. }
  20. }
  21. return stack.pop();
  22. }
  23. }

总结:这几道题目,我们都是先定义个栈对象,然后遍历题目给的字符串或者字符串数组,一边遍历的同时一边进行题目要求的匹配操作,利用栈中的后进先出的规律,进而解决问题。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/运维做开发/article/detail/836350
推荐阅读
相关标签
  

闽ICP备14008679号