• 数据结构与算法(栈)~ 介绍栈以及力扣上几道栈题目的方法和套路


    数据结构与算法(栈)~ 介绍栈以及力扣上几道栈题目的方法和套路

    栈的概念以及特点:是限制在表的一端进行插入和删除操作的线性表。特点: 后进先出

    1,栈的数据结构:

    (1)早期 java.util.Stack 是 继承 Vector 的子类,后期官网不推荐啦

    实现栈特点(使用 双端队列 Deque 的子类 LinkedList 双向链表 便可完美实现 栈 的功能特性)】

    (2)栈主要的功能(增删改查):定义一些接口方法:

    2,栈的力扣算法题:

     总结一些小套路吧 (没有通用的套路,就讲一下方法哈):

     (1)150_逆波兰表达式求值 的方法和套路 :

    方法一:  题意:给的逆波兰表达式就只有 数字和运算符呀, 所以自己写一个方法判断是否非数字即可呀。

     ■ 后缀表达式:
     * 从左至右扫描表达式,遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(次顶元素 op 栈顶元素),
     * 并将结果入栈;重复上述过程直到表达式最右端,最后运算得出的值即为表达式的结果。

     (2)20_有效的括号 的方法和套路 :

    方法一:判断是左括号就入栈,右边括号就出栈左括号与之进行匹配验证(一旦不匹配,返回失败结果)(套路就是:添加哈希表【左括号,右括号】,进行匹配判断)

     (3)224_基本计算器 的方法和套路 :

    方法一:思路:展开。对数据(带上符号)进行累加。默认数据的符号是‘+’ ,遇到:

    ● ‘+’ :与原符号相同(即栈顶)

    ● ‘-’: 与原符号相反(即负 栈顶)

    ● ‘(’:入栈当前符号,(当前符号会影响(的每一个数据的原符号))(入栈当前符号)

    ● ‘)’:出栈当前符号(结束当前符号对(的每个数据的原符号)的影响。)

     (4)856_括号的分数 的方法和套路 :

    方法一:官网的栈的解法(写得太精简了,没看懂)~改为模拟法:

        public int scoreOfParentheses(String s) {
            Stack<String> stack = new Stack<String>();
            for (int i = 0; i < s.length(); i++) {
                char ch = s.charAt(i);
                String ch2 = Character.toString(ch);
                if (ch2.equals("(")) { // 一开始遇到左括号,都是直接入栈
                    stack.push(ch2);
                } else { // 分类:一开始直接是右括号,匹配一对,得一分; 如果遇到是数字,开始计算深度
                    if (ch2.equals(")")) {//这里要加以判断栈顶是否为(,才能匹配
                        if(stack.peek().equals("(")) {
                            stack.pop();
                            stack.push("1");
                        }else {    //逻辑是找到第一对之后才有机会有,进入了此状态后,才有后边的计算,☆☆☆找到第一对 是后边的情况发生前提
                            int depth = 0;
                            String tmp_top = stack.pop();
                            while (!("(".equals(tmp_top))) {
                                depth += Integer.parseInt(tmp_top);
                                tmp_top = stack.pop();
                            }
                            // 跳出循环,说明是遇到左括号了
    //                        stack.pop(); 跳出时就pop() 掉了
                            stack.push(Integer.toString(2 * depth));
                        }
                    } 
                }
            }
            int sum = 0;
            while (!stack.empty()) {
                sum += Integer.parseInt(stack.pop());
            }
            return sum;
        }
  • 相关阅读:
    制作在线简历(一)——Loading与底部菜单
    然而这并没有什么卵用
    移动开发中Fiddler的那些事儿
    多种方法实现Loading(加载)动画效果
    总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解
    SQLServer和MySQL job和 event定时器的差别
    全局ID的重要性
    Windows操作系统上各种服务使用的端口号, 以及它们使用的协议的列表
    Linux发展历史图
    奇特的Local System权限(转载)
  • 原文地址:https://www.cnblogs.com/shan333/p/15455949.html
Copyright © 2020-2023  润新知