使用链表实现队列

使用链表实现队列

 

 


 

 

  1 public class LinkedListQueue2<E> implements Queue<E> {
  2 
  3     private class Node {
  4         public E e;
  5         public Node next;
  6         
  7         public Node(E e, Node next) {
  8             this.e = e;
  9             this.next = next;
 10         }
 11         
 12         public Node(E e) {
 13             this(e, null);
 14         }
 15         
 16         public Node() {
 17             this(null, null);
 18         }
 19         
 20         @Override
 21         public String toString() {
 22             return e.toString();
 23         }
 24     }
 25 
 26     private Node dummyHead, tail;
 27     private int size;
 28     
 29     public LinkedListQueue2() {
 30         dummyHead = new Node();
 31         tail = dummyHead;
 32         size = 0;
 33     }
 34 
 35     @Override
 36     public int getSize() {
 37         return size;
 38     }
 39 
 40     @Override
 41     public boolean isEmpty() {
 42         return size == 0;
 43     }
 44 
 45     @Override
 46     public void enqueue(E e) {
 47 
 48         tail.next = new Node(e);
 49         tail = tail.next;
 50     
 51         size++;
 52     }
 53 
 54     @Override
 55     public E dequeue() {
 56         if(this.isEmpty()) {
 57             throw new IllegalArgumentException("Dequeue failed. Queue is empty.");
 58         }
 59         
 60         Node retNode = dummyHead.next;
 61         dummyHead.next = retNode.next;
 62         retNode.next = null;
 63         if(dummyHead.next == null) {
 64             tail = dummyHead;
 65         }
 66         size--;
 67         return retNode.e;
 68     }
 69 
 70     @Override
 71     public E getFront() {
 72         if(isEmpty()) {
 73             throw new IllegalArgumentException("Queue is empty.");
 74         }
 75         return dummyHead.next.e;
 76     }
 77 
 78     @Override
 79     public String toString() {
 80         StringBuilder res = new StringBuilder();
 81         res.append("Queue: front ");
 82         Node cur = dummyHead.next;
 83         while(cur != null) {
 84             res.append(cur + "->");
 85             cur = cur.next;
 86         }
 87         res.append("NULL tail");
 88         
 89         return res.toString();        
 90     }
 91     
 92     public static void main(String[] args) {
 93         LinkedListQueue2<Integer> queue = new LinkedListQueue2<>();
 94         for(int i=0; i<10; i++) {
 95             queue.enqueue(i);
 96             System.out.println(queue);
 97         
 98             if(i % 3 == 2) {
 99                 queue.dequeue();
100                 System.out.println(queue);
101             }
102         }
103         System.out.println(queue.getSize());
104         for(int i=0; i<7; i++) {
105             queue.dequeue();
106             System.out.println(queue);
107         }
108     }
109 }

 

posted @ 2018-07-10 14:44  小小工匠  阅读(264)  评论(0编辑  收藏  举报