数据结构初阶:Java中的Stack和Queue

Stack(栈)和Queue(队列)。

一.栈

1.1概念

是一种特殊的线性表,栈顶 可以进行插入和删除元素, 栈顶的另一端则为栈底。

添加元素叫做压栈/入栈/进栈, 删除元素叫出栈

栈的特点:先进后出------》先添加进的元素最后才能删除,必须先把头上的元素删了。

1.2栈的使用

常使用的方法:

java 复制代码
import java.util.Stack;

public class Test1 {
    public static void main(String[] args) {
        Stack<Integer> stack = new Stack<>();
        stack.push(1);
        stack.push(2);
        stack.push(3);
        stack.push(4);
        stack.push(5);
        int size=stack.size();
        for (int i = 0; i < size; i++) {
            System.out.println(stack.pop());
        }
    }
}

二.队列

1.1概念

Queue是一个接口,必须实例化LinkedList

队列元素是先进先出。 进行插入操作的一端叫做队尾 ,进行删除操作的一端叫队头

队列拓展了Collection接口。

1.2队列的常用

java 复制代码
Queue<String> queue = new LinkedList<>();
        queue.offer("1");
        queue.offer("12");
        queue.offer("123");
        queue.offer("1234");
        queue.offer("12345");

        int size= queue.size();
        for (int i = 0; i < size; i++) {
            System.out.println(queue.poll());
        }

1.3双端队列

1.3.1概念

Dueue(双端队列)

Dueue是一个拓展了Queue的接口。

双端队列表示队头/队尾都可以进行出队和入队操作。
Deque是一个接口,使用时必须创建LinkedList的对象。

1.3.2双端队列的常用


相关推荐
Byte不洛4 分钟前
哈希表原理 + 冲突解决 + C++实现
数据结构·c++·算法·哈希算法·散列表
_日拱一卒9 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
2401_8685347812 小时前
【无标题】
数据结构·r语言
Mr. zhihao12 小时前
Redis五大高级数据结构:原理-场景-底层-横向对比
数据结构·redis
QiLinkOS12 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
如此这般英俊12 小时前
手撕Claude Code—第一章 agent-loop
数据结构·人工智能·语言模型·自然语言处理
过期动态14 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
青山师14 小时前
动态规划算法深度解析:从状态转移方程到工业级优化
数据结构·算法·面试·动态规划·代理模式·java面试
Severus_black17 小时前
【初阶数据结构与算法】八大排序之非比较排序(计数排序),一次性讲清!
数据结构·算法·排序算法
QiLinkOS17 小时前
从技术到资产的跃迁:企业专利布局的深层逻辑
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源