Review Swift codes (#1150)

* feat(swift): review for chapter_computational_complexity

* feat(swift): review for chapter_data_structure

* feat(swift): review for chapter_array_and_linkedlist

* feat(swift): review for chapter_stack_and_queue

* feat(swift): review for chapter_hashing

* feat(swift): review for chapter_tree

* feat(swift): add codes for heap article

* feat(swift): review for chapter_heap

* feat(swift): review for chapter_graph

* feat(swift): review for chapter_searching

* feat(swift): review for chapter_sorting

* feat(swift): review for chapter_divide_and_conquer

* feat(swift): review for chapter_backtracking

* feat(swift): review for chapter_dynamic_programming

* feat(swift): review for chapter_greedy

* feat(swift): review for utils

* feat(swift): update ci tool

* feat(swift): trailing closure

* feat(swift): array init

* feat(swift): map index
This commit is contained in:
nuomi1
2024-03-20 21:15:39 +08:00
committed by GitHub
parent 300a781fab
commit 7359a7cb4b
55 changed files with 293 additions and 224 deletions

View File

@ -7,12 +7,14 @@
/* */
class ArrayQueue {
private var nums: [Int] //
private var front = 0 //
private var queSize = 0 //
private var front: Int //
private var _size: Int //
init(capacity: Int) {
//
nums = Array(repeating: 0, count: capacity)
front = 0
_size = 0
}
/* */
@ -22,12 +24,12 @@ class ArrayQueue {
/* */
func size() -> Int {
queSize
_size
}
/* */
func isEmpty() -> Bool {
queSize == 0
size() == 0
}
/* */
@ -38,10 +40,10 @@ class ArrayQueue {
}
// + 1
// rear
let rear = (front + queSize) % capacity()
let rear = (front + size()) % capacity()
// num
nums[rear] = num
queSize += 1
_size += 1
}
/* */
@ -50,7 +52,7 @@ class ArrayQueue {
let num = peek()
//
front = (front + 1) % capacity()
queSize -= 1
_size -= 1
return num
}
@ -65,11 +67,7 @@ class ArrayQueue {
/* */
func toArray() -> [Int] {
//
var res = Array(repeating: 0, count: queSize)
for (i, j) in sequence(first: (0, front), next: { $0 < self.queSize - 1 ? ($0 + 1, $1 + 1) : nil }) {
res[i] = nums[j % capacity()]
}
return res
(front ..< front + size()).map { nums[$0 % capacity()] }
}
}