[数据结构]单调栈

单调栈

这是笔者的第一篇博客,由于笔者自身水平的限制。用词可能不够准确,句子不太通顺,代码水平可能也不太行,敬请指出,感激不尽!

我们都知道栈(Stack)是一种先入后出的数据结构,而单调栈建立在栈的基础上,它区别于普通的栈的特殊之处在于

栈中的元素一直保持着单调递增/单调递减的关系

比如单调递增栈中的元素自栈底至栈顶元素(0~n-1)间都是单调递增的,单调递减栈中的元素都是单调递减的。

为了加深印象,我们可以先以单调递减栈为例,看一个例子~

有一组数nums[6] = {10,1,8,12,6,4}按照如下规则进行操作:

  1. 如果栈为空/正在处理的数小于栈顶的数,则进栈;
  2. 如果正在处理的数大于栈顶的数,则将栈顶元素出栈,然后继续进行判断。

OK,首先我们将栈置空,然后再来一个一个地读数。

  1. 首先读到了10,此时栈为空,10进栈,现在栈的状态: {10}

  2. 读到了1,栈顶元素为10,1<10,1进栈,栈的状态: {10 , 1}

  3. 读到8,栈顶元素为1,8>1,那么我们将1出栈;

    继续判断,8<10,所以8进栈,栈的状态: {10,8}

  4. 读到数12,栈顶元素为8,12>8,将8出栈;

    继续判断,12>10,所以10出栈,此时栈已为空,将12进栈: {12}

  5. 读到6,6<12,进栈;{12,6}

  6. 读到4,4<6,将4进栈。 {12,6,4}

读到这边࿰

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值