时间:2021-05-19
初谈这个话题,相信许多人会有一种似有所悟,但又不敢确定的感觉。没错,这正是因为其中“单调”一词的存在,所谓单调是什么,学过函数的people都知道单调函数或者函数的单调性,直白一点说单调就是一直增或一直减。例如:1,3,5,9就是一个单调增数列,数列中不存在后一个数比前一个数小的现象。那么同样,在这里谈到的话题也有类似特点。
先说一下单调队列吧! 单调队列,就是一个符合单调性质的队列,它同时具有单调的性质以及队列的性质。他在编程中使用频率不高,但却占有至关重要的地位。它的作用很简单,就是为了维护一组单调数据,让我们在运行的过程中能够快速寻求前k个或后k个中最大或最小的值。 至于单调栈,相信看完上面的叙述后,都会有一个大概的理解,单调栈就是一个符合单调性质的栈它同时具有单调的性质以及栈的性质。在作用方面两者是相同的,差别仅是在编程过程中所维护的数组的方式不同。
下面我会举个简单的列子来解释单调队列及单调栈。
例题:有一组数据1,5,9,4,7,8,6,他们会依此输入,同时,在某一时刻会让你求出后n个数中的最大值。
根据题意,我们可以得出这样一个结论,若后一个数大于前一个数,则结果必定不会是前一个数(比如现在输入了1,5,由于1<5,所以无论是后几个数中的最大值均不会为1),因此,我们只需维护一个单调递减的数组便可快速求得所需之。(数组变化如下:输入——1,数组——1;输入——5,由于5>1删去1添入5,数组——5;输入——9,由于9>5删去5添入9,数组——9;输入——4,由于4<9直接添入,数组——9,4;输入——7,由于7>4同时7<9因此删去4添入7,数组——9,7;输入——8,由于8>4同时8<9因此删去7添入8,数组——9,8;输入——6,由于6<8直接添入,数组——9,8,6。)
单调队列及单调栈的基础也就这些,剩下的就只剩下个人理解及练习了。推荐几道题,在大视野上的1012以及1047,其中1012比较裸适合初学者做,1047略有难度推荐做完1012后再做。(在这里给个提示,1047要用到两次单调队列、单调栈,横着一次再用结果竖这一次。)
以上就是本文的全部内容了,希望对你有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
题目描述输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。解答:/*publicclassListNode{intva
一、概述栈和队列在数据结构中是比较重要的一个数据结构。其实对于栈和队列并不需要太深入的介绍,栈和队列的核心内容是栈是先进后出、队列是先进先出。在实际开发中有些场
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。1、迭代方法defMerge(self,pHead1,pHead2)
C++数据结构实现两个栈实现一个队列栈为后进先出,队列为先进先出用两个栈实现一个队列。是一个比较经典的问题。看到这个问题,我的第一个解题思路为:定义两个栈,s1
本文实例讲述了PHP使用两个栈实现队列功能的方法。分享给大家供大家参考,具体如下:问题用两个栈来实现一个队列,完成队列的Push和Pop操作。队列中的元素为in