栈与队列简介
栈与队列和数组、链表、树这几种数据结构不太一样。栈与队列主要是做为程序员的工具来使用,它们主要做为构思算法的辅助工具,而不是完全的数据存储工具。
它们的生命周期比数组那些要短得多,在程序执行期间它们才会被创建,任务执行完就会被销毁。
一 栈
栈是一种只能在一端进行插入和删除数据的数据结构,这一端被称为栈顶(top)。其特点简单来讲就是先进后出。栈的主要机制可以用数组来实现,当然也可以用链表来实现。
用数组实现栈,并完成常用操作——出栈、入栈、查看元素(只能查看栈顶元素)、判断栈是否为空等操作。
栈的所有操作复杂度都为O(1),栈的操作不依赖栈中元素大小,栈不需要移动和比较操作。
二 队列
队列的特点是先进先出。队列也是用数组来实现。
用数组实现队列,并完成常用操作——出队、入队、查看元素、判断队列是否为空等操作。
队列的插入、删除等操作的复杂度都为O(1)。
三 优先级队列
优先级队列和普通队列一样,也是一个队头,一个队尾,从队头移除元素,优先级队列中,数据项是有序的,这样插入数据的时候就会根据某种规则去比较,然后插入到队列合适的位置。因此,优先级队列插入的复杂度为O(N),删除和查看元素的复杂度为O(1)。
用数组实现优先级队列,并完成常用操作——出队、入队、查看元素、判断队列是否为空等操作。
四 总结
栈的特点是先进后出,栈只能查看栈顶的一个元素
队列的特点是先进先出,只能查看队头的一个元素
优先级队列插入一条元素,平均需要移动2/N个元素,因此插入的复杂度为O(N)
栈和队列,可以用数组实现,也可以用其他数据结构实现
栈和队列是为了完成某些工作,手动构造的数据结构
点关注、不迷路
如果觉得文章不错,欢迎关注、*点赞*、收藏,你们的支持是我创作的动力,感谢大家。
如果文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。
如果你还想更加深入的了解我,可以微信搜索「Java旅途」进行关注。回复「1024」即可获得学习视频及精美电子书。每天7:30准时推送技术文章,让你的上班路不在孤独,而且每月还有送书活动,助你提升硬实力!
版权声明: 本文为 InfoQ 作者【Java旅途】的原创文章。
原文链接:【http://xie.infoq.cn/article/cd4dec73f2f4a87d305bf177f】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论