首页 > Java > java教程 > 正文

java栈与队列如何实现

WBOY
发布: 2023-04-18 15:52:03
转载
1034人浏览过

栈与队列

  1. 栈 (stack)是一种后进先出(last in first off,lifo)的数据结构

  2. 队列(Queue)则是一种先进先出 (fisrt in first out,FIFO)的结构

栈 (Stack)

栈是一种线性结构,与数组相比,栈对应的操作是数组的子集。

它只能从一端添加元素,也只能从一端取出元素(这一端称之为栈顶)。

Stack这种数据结构用途很广泛,在计算机的使用中,大量的运用了栈,比如编译器中的词法分析器、Java虚拟机、软件中的撤销操作(Undo)、浏览器中的回退操作,编译器中的函数调用实现等等。

立即学习Java免费学习笔记(深入)”;

栈的实现

接口 说明 复杂度
void push(E e) 向栈中加入元素 O(1) 均摊
E pop() 弹出栈顶元素 O(1) 均摊
E peek() 查看栈顶元素 O(1)
int getSize() 获取栈中元素个数 O(1)
boolean isEmpty() 判断栈是否为空 O(1)

说明:push和pop操作在最后面进行,有可能触发resize,但均摊来算是O(1)的。
如果你想了解更多时间复杂度的分析,欢迎关注笔者后续要更新的文章:O(n)说明的是什么问题?

栈的实现可以通过 数组 或者 链表 实现,在这里我们使用 数组来实现上述接口。

在栈的设计中,用户只关注栈顶元素存取和栈长度,因此设计代码如下:

ViiTor实时翻译
ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116
查看详情 ViiTor实时翻译

java栈与队列如何实现

读者可以使用 栈 这种数据结构去解决LeetCode上的第20号问题:有效的括号,也可以查看 每天一算:Valid Parentheses。

队列 Queue

队列也是一种线性数据结构,与数组相比,队列对应的操作是数组的子集。

只能从一端 (队尾) 添加元素,只能从另一端 (队首) 取出元素。

队列的应用可以在播放器上的播放列表,数据流对象,异步的数据传输结构(文件IO,管道通讯,套接字等)上体现,当然最直观的的就是排队了。

队列的实现

接口 说明 复杂度
void enqueue(E e) 入队 O(1) 均摊
E dequeue() 出队 O(n)
E getFront() 获取队首元素 O(1)
int getSize() 获取队列元素个数 O(1)
boolean isEmpty() 判断队列是否为空 O(1)

入队是从队尾开始,有可能触发resize,因此均摊下来是O(1)。出队是在队首,数组实现每次都要挪动所有元素,O(n)。

java栈与队列如何实现

以上就是java栈与队列如何实现的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:亿速云网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号