• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 浅谈单调队列、单调栈

浅谈单调队列、单调栈

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了栈和队列,栈和队列的共同点是,栈和队列的区别,栈和队列的共同特点是,数据结构栈和队列等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

初谈这个话题,相信许多人会有一种似有所悟,但又不敢确定的感觉。没错,这正是因为其中“单调”一词的存在,所谓单调是什么,学过函数的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要用到两次单调队列、单调栈,横着一次再用结果竖这一次。)

以上就是本文的全部内容了,希望对你有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言 表、栈和队列详解及实例代码
  • C语言对栈的实现基本操作
  • C语言 数据结构中栈的实现代码
  • 详解数据结构C语言实现之循环队列
  • 浅析C语言中堆和栈的区别
  • 深入浅析C语言中堆栈和队列
  • 使用C语言来解决循环队列问题的方法
  • 浅谈单调队列、单调栈
  • 探讨:用两个栈实现一个队列(我作为面试官的小结)
  • 数据结构课程设计-用栈实现表达式求值的方法详解

相关文章

  • 2017-05-28用while判断输入的数字是否回文数的简单实现
  • 2017-05-28判断一个数是不是素数的方法
  • 2017-05-28针对Ruby的Selenium WebDriver安装指南
  • 2017-05-28Linux下C语言修改进程名称的方法
  • 2017-05-28C++之普通成员函数、虚函数以及纯虚函数的区别与用法要点
  • 2017-05-28浅析iterator与指针的区别
  • 2017-05-28基于堆的基本操作的介绍
  • 2017-05-28深入浅析STL vector用法
  • 2017-05-28基于C语言char与unsigned char的区别介绍
  • 2017-05-28详解C++编程中的静态成员与可变数据成员

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C++中对象的常引用总结
    • C++ ofstream与ifstream详细用法
    • 英语和数学不好,能学编程吗?
    • 详解安卓系统中的Android.mk文件
    • c++静态局部变量和静态函数示例
    • VC创建进程CreateProcess的方法
    • C语言中字符串和数字的相互转换实现代码
    • C++中typedef 及其与struct的结合使用
    • C++中用指向数组的指针作函数参数
    • C++的static关键字及变量存储位置总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有