news 2026/7/5 4:33:36

【java入门到放弃】算法中队列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【java入门到放弃】算法中队列

1、普通队列

FIFO、全称:First In, First Out、中文意思:先进先出

offer / poll / peek(安全)或add / remove / element(严格(为null会抛异常))

publicstaticvoidmain(String[]args){// 用 LinkedList 实现普通队列Queue<Integer>queue=newArrayDeque<>();// 入队offerqueue.offer(1);queue.offer(2);queue.offer(3);// 查看队首peekSystem.out.println(queue.peek());// 1// 出队pollSystem.out.println(queue.poll());// 1System.out.println(queue.poll());// 2// 再出队System.out.println(queue.poll());// 3System.out.println(queue.poll());// null}

2、双端队列

publicstaticvoidmain(String[]args){Deque<Integer>deque=newArrayDeque<>();// 队尾入队deque.offerLast(1);deque.offerLast(2);// 队首入队deque.offerFirst(0);// 查看队首和队尾System.out.println(deque.peekFirst());// 0System.out.println(deque.peekLast());// 2// 出队System.out.println(deque.pollFirst());// 0System.out.println(deque.pollLast());// 2}

3、栈

LIFO、后进先出

publicstaticvoidmain(String[]args){// 创建一个栈(使用 ArrayDeque)Deque<String>stack=newArrayDeque<>();// 1. push(E e) 压栈stack.push("苹果");stack.push("香蕉");stack.push("橘子");System.out.println("压栈后: "+stack);// [橘子, 香蕉, 苹果]// 2. peek() 查看栈顶元素Stringtop=stack.peek();System.out.println("栈顶元素: "+top);// 橘子System.out.println("查看后栈: "+stack);// 栈内容不变// 3. pop() 弹栈Stringremoved=stack.pop();System.out.println("弹出的元素: "+removed);// 橘子System.out.println("弹栈后栈: "+stack);// [香蕉, 苹果]// 4. isEmpty() 判断栈是否为空System.out.println("栈是否为空? "+stack.isEmpty());// false// 5. size() 栈中元素数量System.out.println("栈中元素数量: "+stack.size());// 2// 再弹一次stack.pop();stack.pop();System.out.println("全部弹出后,栈是否为空? "+stack.isEmpty());// true}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 16:49:51

终极指南:使用urdf-viz快速实现URDF可视化

终极指南&#xff1a;使用urdf-viz快速实现URDF可视化 【免费下载链接】urdf-viz 项目地址: https://gitcode.com/gh_mirrors/ur/urdf-viz 想要轻松查看和交互机器人模型吗&#xff1f;&#x1f680; urdf-viz 是一个基于 Rust 开发的免费开源工具&#xff0c;专门用于…

作者头像 李华
网站建设 2026/7/4 16:42:37

如何在10分钟内快速搭建MosDNS:打造高性能DNS转发器的完整教程

如何在10分钟内快速搭建MosDNS&#xff1a;打造高性能DNS转发器的完整教程 【免费下载链接】mosdns mosdns - 一个DNS转发器&#xff0c;使用Go语言编写&#xff0c;遵循GPLv3许可。 项目地址: https://gitcode.com/gh_mirrors/mo/mosdns MosDNS是一款基于Go语言开发的高…

作者头像 李华
网站建设 2026/7/1 22:47:25

AI时代的思考力:程序员构建个人知识体系的完整路径!

简介 本文探讨了AI时代程序员如何提升思考力&#xff0c;构建完整知识体系。强调思考应向洞察力和反思力两端移动&#xff0c;通过业务、技术、管理和软技能四维度并行发展&#xff0c;结合长期主义坚持和写作实践&#xff0c;形成学习-实践-复盘的闭环迭代。AI工具可辅助快速…

作者头像 李华
网站建设 2026/7/5 0:41:13

基于大语言模型的产量预测方法

第一步&#xff1a;下载预训练GPT模型&#xff08;transformers库一键下载&#xff09;第二步&#xff1a;编写数据处理器&#xff08;处理你的数据&#xff09;第三步&#xff1a;创建适配器模型&#xff08;修改GPT用于时序预测&#xff09;第四步&#xff1a;训练模型&#…

作者头像 李华
网站建设 2026/7/4 2:46:44

当开题报告还在“憋字”?不如让AI帮你搭好科研第一块积木

在高校的深夜自习室里&#xff0c;总有一群人对着空白的Word文档发呆——不是没思路&#xff0c;而是卡在“如何把思路变成一份规范、严谨、逻辑严密的开题报告”。尤其对初涉科研的硕博新生而言&#xff0c;“开题”二字几乎等同于“焦虑源”&#xff1a;研究背景怎么写才不空…

作者头像 李华