栈的几个经典应用,真的绝了

一、我们了解的栈

自从最开始接触栈之后,我就知道了栈是一个先进后出数据结构,一直到现在也没忘记这个特点。也就是说访问栈里面的元素顺序是从最近插入的开始访问。但是栈的使用场景其实了解的不多,本文就来总结下栈有哪些经典使用场景吧。

二、栈的经典应用

1、栈其实可以用来实现队列

栈的特点是先进后出,而队列的特点是先进先出

如果我们使用两个栈,可以实现队列的功能,双栈实现队列。

如上图,我们通过将第一个栈的数据导入第二个栈,再通过第二个栈出栈,实现队列先进先出的特性。

2、栈可以用于对称匹配,如匹配有效的括号有效的算式表达式

比如有一串括号字符串,([{}]),我们需要判断括号是否完全匹配。

通过将一边的括号入栈,遇到了对边的括号,需要出栈匹配。

我们可以发现,}])和出栈的括号顺序可以匹配,如果括号完全匹配,那么最终栈里面没有一个元素。

三、栈应用实战

leetcode20. 有效的括号

java 复制代码
class Solution {
    public boolean isValid(String s) {
        int n = s.length();
        //存储关系
        Map<Character, Character> map = new HashMap<Character, Character>() {{
            put(')', '(');
            put(']', '[');
            put('}', '{');
        }};
        Stack<Character> stack = new Stack<Character>();
        for (int i = 0; i < n; i++) {
            char ch = s.charAt(i);
            //是右边的括号
            if (map.containsKey(ch)) {
                //栈顶没有匹配的左边括号
                if (stack.isEmpty() || stack.peek() != map.get(ch)) {
                    return false;
                }
                stack.pop();
            } else {
                //左边的括号,入栈
                stack.push(ch);
            }
        }
        //栈里如果还要括号,则不匹配
        return stack.isEmpty();
    }
}

四、总结

栈的特性先进后出理解很简单,但是实际操作是有一定难度的,看完栈的应用,发现栈可以解决的问题还是非常有意思的。

相关推荐
黎阳之光1 分钟前
黎阳之光:全域实景立体管控,重构智慧电厂与变电站数字孪生新范式
大数据·人工智能·算法·安全·数字孪生
jwt7939279372 分钟前
Spring之DataSource配置
java·后端·spring
黑牛儿2 分钟前
Swoole协程 vs Go协程:PHP开发者一看就懂的实战对比
后端·golang·php·swoole
嘻嘻哈哈樱桃4 分钟前
数据流中的中位数 力扣--160
算法·leetcode·职场和发展
Rust研习社4 分钟前
深入理解 Rust 裸指针:内存操作的双刃剑
开发语言·后端·rust
老约家的可汗5 分钟前
深入浅出:Map与Set的核心原理与使用场景
数据结构·算法
j_xxx404_10 分钟前
深入理解Linux底层存储:从物理磁盘架构到文件系统(inode/Block)原理
linux·运维·服务器·后端
逻辑驱动的ken10 分钟前
Java高频面试场景题07
java·开发语言·面试·职场和发展·求职招聘·春招
j_xxx404_12 分钟前
力扣算法题:字符串(最长公共前缀|最长回文子串)
c++·算法·leetcode
承渊政道14 分钟前
【递归、搜索与回溯算法】(穷举vs暴搜vs深搜vs回溯vs剪枝:一文讲清概念与用法)
数据结构·c++·算法·决策树·深度优先·剪枝·宽度优先