赞
踩
Java双端队列
典型的双端队列收集如下所示:
双端队列(Deque:double ended queue)就是一个两端都是结尾的队列。队列的每一端都可以插入数据项和移除数据项。相对于普通队列,双端队列的入队和出队操作在两端都可进行。
left:左端 right:右端
这里我们使用最常用的顺序结构来存储双端队列,为了节省空间,把它首尾相连,构成循环队列。并且规定left指向左端的第一个元素,right指向右端的下一个位置。那么队空的判断则是left==right,队满是(left-1+MAX)%MAX==right或者(right-left+MAX)%MAX==MAX。
创建实现双端队列方法类:
class ListNode { //数据域 public int val; //指针 public ListNode next; //初始化值 public ListNode(int val) { this.val = val; } } public class Deque { public ListNode head;//头结点 public ListNode last;//尾节点 //在双端队列头那边添加节点变成新的头结点 //在第一个节点处添加一个节点 public void addFirst(int val) { //创建对象初始化值建立新节点 ListNode node = new ListNode(val); //判断尾节点是否为空 if (this.last == null) { //若为空就是头结点尾节点都是这个新创建的节点 this.head = node; this.last = node; } //node成为新的头节点 node.next = this.head; this.head = node; } //在双端队列尾那边添加节点变成新的尾节点 //在节点的最后添加一个节点 public void addLast(int val) { //创建对象初始化值建立新节点 ListNode node = new ListNode(val); //判断尾节点是否为空 if (this.last == null) { //若为空就是头结点尾节点都是这个新创建的节点 this.head = node; this.last = node; } //node成为新的尾节点 this.last.next = node; this.last = node; } //从头结点那边拿出Deque的一个节点 public int offerFirst() { //判断头节点是否为空,如果是就输出! if (this.head == null) { System.out.println("!"); return -1; } //如果不为空,把头结点指向的值拿出来 int oldValue = this.head.val; //判断头结点尾节点是否重合,如果重合就表明双端队列为空 if (this.head == this.last) { this.head = null; this.last = null; } else { //没有重合就接着找下一个节点变成新的头结点 this.head = this.head.next; } return oldValue; } //从尾结点那边拿出Deque的一个节点 public int offerLast() { //判断尾节点是否为空,如果就输出! if (this.last == null) { System.out.println("!"); return -1; } // //如果不为空,把尾结点指向的值拿出来 int oldValue = this.last.val; //判断头结点尾节点是否重合,如果重合就表明双端队列为空 if (this.head == this.last) { this.last = null; this.head = null; } else { //遍历找到新的尾节点 ListNode cur = this.head; while (cur.next != last) { cur = cur.next; } //把找到的最后一个节点做为尾节点 this.last = cur; //尾节点.next=null this.last.next = null; } return oldValue; } //获取Deque处第一个节点的值 public int peekFirst() { //判断头结点是否为空,是就输出! if (this.head == null) { System.out.println("!"); return -1; } //返回头结点值 return this.head.val; } //获取Deque上最后一个节点的值 public int peekLast() { //判断尾结点是否为空,是就输出! if (this.last == null) { System.out.println("!"); return -1; } //返回尾结点值 return this.last.val; } //Check whether the Deque is empty public boolean empty() { return this.head == null; } public void display(){ ListNode cur =head; while (cur!=last) { System.out.println(cur.val); cur = cur.next; } System.out.println(cur.val); } }创建测试类:
public class DequeTest { public static void main(String[] args) { Deque deque=new Deque(); deque.addFirst(1); deque.addFirst(2); deque.addFirst(3); deque.display(); deque.offerFirst(); System.out.println(); deque.display(); } }测试结果:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。