-
Notifications
You must be signed in to change notification settings - Fork 16
Expand file tree
/
Copy pathSequenceQueue.java
More file actions
174 lines (146 loc) · 3.57 KB
/
SequenceQueue.java
File metadata and controls
174 lines (146 loc) · 3.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
package com.qingtian.source.queue.impl;
import com.qingtian.source.queue.Queue;
import java.util.Arrays;
/**
* @author mcrwayfun
* @version v1.0
* @date Created in 2018/08/04
* @description 数组构建队列
*/
public class SequenceQueue<E> implements Queue<E> {
// 队列默认长度
private int DEFAULT_SIZE = 10;
// 用来保存队列元素的数组
private Object[] elementData;
// 保存数组的长度。
private int capacity;
// 队列头元素位置
private int front = 0;
// 队列尾元素位置
private int rear = 0;
/**
* 初始化数组长度和数组
*/
public SequenceQueue() {
this.capacity = DEFAULT_SIZE;
elementData = new Object[capacity];
}
/**
* 以一个初始元素来构建队列
*
* @param value
*/
public SequenceQueue(E value) {
this();
elementData[0] = value;
rear++;
}
/**
* 以指定长度的数组来创建队列
*
* @param value 指定顺序中的第一个元素
* @param initSize 数组长度
*/
public SequenceQueue(E value, int initSize) {
this.capacity = initSize;
elementData = new Object[capacity];
elementData[0] = value;
rear++;
}
/**
* 判断队列是否为空
*
* @return
*/
@Override
public boolean isEmpty() {
return front == rear;
}
/**
* 入队
*
* @param data
* @throws IndexOutOfBoundsException
*/
@Override
public void push(E data) {
// 检查队列是否已经满了
checkQueueIsFull();
elementData[rear++] = data;
}
/**
* 出队,推出元素
*
* @return
* @throws IndexOutOfBoundsException
*/
@Override
@SuppressWarnings("unchecked")
public E pop() {
// 检查队列是否为空
checkQueueIsEmpty();
E oldValue = (E) elementData[front];
// 释放队列已经出栈的元素
elementData[front++] = null;
return oldValue;
}
/**
* 推出元素但不出队
*
* @return
* @throws IndexOutOfBoundsException
*/
@Override
@SuppressWarnings("unchecked")
public E peek() {
// 检查队列是否为空
checkQueueIsEmpty();
return (E) elementData[front];
}
/**
* 清空队列中的元素
*/
@Override
public void clear() {
// 将所有元素赋值为null
Arrays.fill(elementData, null);
front = rear = 0;
}
/**
* 获取顺序队列的大小
*
* @return
*/
@Override
public int length() {
return rear - front;
}
public String toString() {
if (isEmpty()) {
return "[]";
} else {
StringBuilder sb = new StringBuilder("[");
for (int i = front; i < rear; i++) {
sb.append(elementData[i].toString() + ", ");
}
int len = sb.length();
return sb.delete(len - 2, len).append("]").toString();
}
}
/**
* 判断队列是否为空,若为空则抛出IndexOutOfBoundsException
*/
private void checkQueueIsEmpty() {
if (isEmpty()) {
throw new IndexOutOfBoundsException("队列为空");
}
}
/**
* 判断队列是否已经满了,若满了则抛出IndexOutOfBoundsException
*/
private void checkQueueIsFull() {
if (rear > capacity - 1) {
throw new IndexOutOfBoundsException("队列已经满了");
}
}
}