dequeue java_Java中的Dueue和Deque

队列(queue)是一种常用的数据结构,可以将队列看做是一种特殊的线性表,该结构遵循的先进先出原则。Java中,LinkedList实现了Queue接口,因为LinkedList进行插入、删除操作效率较高

相关常用方法:

boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。

E poll():从队首删除并返回该元素。

E peek():返回队首元素,但是不删除

public class QueueDemo {

public static void main(String [] args) {

Queue queue = new LinkedList();

//追加元素

queue.offer("one");

queue.offer("two");

queue.offer("three");

queue.offer("four");

System.out.println(queue);

//从队首取出元素并删除

String poll = queue.poll();

System.out.println(poll);

System.out.println(queue);

//从队首取出元素但是不删除

String peek = queue.peek();

System.out.println(peek);

System.out.println(queue);

//遍历队列,这里要注意,每次取完元素后都会删除,整个

//队列会变短,所以只需要判断队列的大小即可

while(queue.size() > 0) {

System.out.println(queue.poll());

}

}

}

运行结果:

[one, two, three, four]

one

[two, three, four]

two

[two, three, four]

two

three

four

双向队列(Deque),是Queue的一个子接口,双向队列是指该队列两端的元素既能入队(offer)也能出队(poll),如果将Deque限制为只能从一端入队和出队,则可实现栈的数据结构。对于栈而言,有入栈(push)和出栈(pop),遵循先进后出原则

常用方法如下:

void push(E e):将给定元素”压入”栈中。存入的元素会在栈首。即:栈的第一个元素

E pop():将栈首元素删除并返回。

public class DequeDemo {

public static void main(String[] args) {

Deque deque = new LinkedList();

deque.push("a");

deque.push("b");

deque.push("c");

System.out.println(deque);

//获取栈首元素后,元素不会出栈

String str = deque.peek();

System.out.println(str);

System.out.println(deque);

while(deque.size() > 0) {

//获取栈首元素后,元素将会出栈

System.out.println(deque.pop());

}

System.out.println(deque);

}

}

运行结果:

[c, b, a]

c

[c, b, a]

c

b

a

[]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值