Fix array queue.

This commit is contained in:
Yudong Jin
2023-02-01 03:23:29 +08:00
parent 658ad90377
commit 5eae708035
15 changed files with 425 additions and 365 deletions

View File

@ -7,8 +7,8 @@
/* */
class ArrayQueue {
private var nums: [Int] //
private var front = 0 //
private var rear = 0 // + 1
private var front = 0 //
private var queSize = 0 //
init(capacity: Int) {
//
@ -22,14 +22,12 @@ class ArrayQueue {
/* */
func size() -> Int {
let capacity = capacity()
// rear < front
return (capacity + rear - front) % capacity
queSize
}
/* */
func isEmpty() -> Bool {
rear - front == 0
queSize == 0
}
/* */
@ -38,19 +36,22 @@ class ArrayQueue {
print("队列已满")
return
}
// + 1
// rear
int rear = (front + queSize) % capacity();
// num
nums[rear] = num
//
rear = (rear + 1) % capacity()
nums[rear] = num;
queSize++;
}
/* */
@discardableResult
func poll() -> Int {
let num = peek()
//
front = (front + 1) % capacity()
return num
//
front = (front + 1) % capacity();
queSize--;
return num;
}
/* 访 */
@ -63,12 +64,10 @@ class ArrayQueue {
/* */
func toArray() -> [Int] {
let size = size()
let capacity = capacity()
//
var res = Array(repeating: 0, count: size)
for (i, j) in sequence(first: (0, front), next: { $0 < size - 1 ? ($0 + 1, $1 + 1) : nil }) {
res[i] = nums[j % capacity]
var res = Array(repeating: 0, count: queSize)
for (i, j) in sequence(first: (0, front), next: { $0 < queSize - 1 ? ($0 + 1, $1 + 1) : nil }) {
res[i] = nums[j % capacity()]
}
return res
}