LinkedList与ArrayDeque在栈与队列中的使用

LinkedList

增加:

  • add(E e):在链表后添加一个元素; 通用方法
  • addFirst(E e):在链表头部插入一个元素; 特有方法
  • addLast(E e):在链表尾部添加一个元素; 特有方法
  • offer(E e):在链表尾部插入一个元素
  • add(int index, E element):在指定位置插入一个元素。
  • offerFirst(E e):JDK1.6版本之后,在头部添加; 特有方法
  • offerLast(E e):JDK1.6版本之后,在尾部添加; 特有方法

删除:

  • remove() :移除链表中第一个元素; 通用方法
  • remove(E e):移除指定元素; 通用方法
  • removeFirst(E e):删除头,获取元素并删除; 特有方法
  • removeLast(E e):删除尾; 特有方法
  • pollFirst():删除头; 特有方法
  • pollLast():删除尾; 特有方法
  • ==pop():和removeFirst方法一致,删除头。 ==
  • ==poll():查询并移除第一个元素 特有方法 ==

查:

  • get(int index):按照下标获取元素; 通用方法
  • getFirst():获取第一个元素; 特有方法
  • getLast():获取最后一个元素; 特有方法
  • peek():获取第一个元素,但是不移除; 特有方法
  • peekFirst():获取第一个元素,但是不移除;
  • peekLast():获取最后一个元素,但是不移除;
  • pollFirst():查询并删除头; 特有方法
  • pollLast():删除尾; 特有方法
  • poll():查询并移除第一个元素 特有方法

ArrayDeque

特点:

  • ArrayDeque实现了Deque接口。可当作栈来用,效率高于stack。也可当作队列来用,效率高于LinkedList。
  • 底层用可变数组实现,无容量限制。
  • ArrayDeque是不安全的。

增加:

  • addFirst(E e)在数组前面添加元素
  • addLast(E e)在数组后面添加元素
  • offerFirst(E e)在数组前面添加元素,并返回是否添加成功
  • offerLast(E e)在数组后添加元素,并返回是否添加成功
  • push(E e):与addFirst方法一致
  • offer(E e):在链表尾部插入一个元素
    删除:
  • removeFirst()删除第一个元素,并返回删除元素的值,如果为null,将抛出异常
  • removeLast()删除最后一个元素,并返回删除元素的值,如果为null,将抛出异常
  • pollFirst()删除第一个元素,并返回删除元素的值,如果为null,将返回null
  • pollLast()删除最后一个元素,并返回删除元素的值,如果为null,将返回null
  • ==pop():和removeFirst方法一致,删除头。 ==
  • poll():查询并移除第一个元素 特有方法
    查:
  • getFirst()获取第一个元素,如果为null,将抛出异常
  • getLast()获取最后一个元素,如果为null,将抛出异常
  • peek():获取第一个元素,但是不移除; 特有方法

注意

add() 和 offer()的区别

  • 在容量已满的情况下,add() 方法会抛出IllegalStateException异常,offer() 方法只会返回 false
  • remove方法和poll方法都是删除队列的头元素,remove方法,队列为空的情况下将抛异常,而poll方法将返回null;
  • element和peek方法都是返回队列的头元素,但是不删除头元素,区别在与element方法在队列为空的情况下,将抛异常,而peek方法将返回null。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值