栈:从普通栈到单调栈

本文介绍了栈在程序执行和表达式计算中的应用,并重点讨论了单调栈的概念和使用,包括有效括号的检查、每日温度问题以及在解决Bad Hair Day问题中的作用。通过单调栈,可以高效地找到比当前元素更大或更小的后续元素。
摘要由CSDN通过智能技术生成

请添加图片描述

栈的应用场景

栈是一种先进后出的数据结构(类比弹夹),在程序执行过程中,栈可以说是应用最广泛的数据结构之一了。

Java方法执行的时候会把方法的相关信息封装到一个栈帧放入虚拟机中。例如当methodOne调用methodTwo,methodTwo调用methodThree执行时,虚拟栈如下所示。当methodThree执行完毕则会出栈,methodTwo执行完毕出栈。即方法调用入栈,方法执行出栈
请添加图片描述
简单的一个表达式计算的过程也会用到操作数栈
请添加图片描述

(100+200)*300的计算过程如下

  1. 将100入栈
  2. 将200入栈
  3. 弹出栈顶的2个元素100和200,相加后入栈
  4. 将300入栈
  5. 弹出栈顶的2个元素300和200,相乘后入栈

有效括号

题目地址:LeetCode 20. 有效的括号

给定一个只包括 ‘(’,’)’,’{’,’}’,’[’&

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java识堂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值