Skip to content

🦸‍♂️A Deque collection type implemented with Swift's protocols: Sequence, Collection, MutableCollection, and BidirectionalCollection with using of circular buffer to maximize memory usage

Notifications You must be signed in to change notification settings

tornikegomareli/Deque

Repository files navigation

Medium article banner

Twitter: @tornikegomareli Linkedin: @Linkedin

Using a circular buffer as storage, the Deque custom collection type in Swift offers a double-ended queue data structure. At both ends of the queue, it enables efficient insertion and removal operations.

This implementation still requires some performance optimizations, such as lazy resizing and the use of a custom index type to prevent pointless range checks. Although I believe it is enough for my Medium article, which is the reason for this, and data structure is doing its job in this context, I may add more improvements in the future, solely for educational uses.

Please refrain from using this data structure in your projects as it is a long way from being ready for production.

Usage

To use Deque in your project, simply install it with SPM. Then, you can create a new instance of Deque with the desired capacity

var deque = Deque<Int>(capacity: 10)
deque.prepend(1)
deque.append(1)
deque.removeLast()
deque.removeFirst()

You can then use the append, prepend, removeFirst, and removeLast methods to add and remove elements from the deque.

Deque also conforms to the Collection protocol and Sequence Protocol, so you can use it in any context that expects a collection or Sequence.

Contributing

This implementation is for educational purposes and created for an article. However, if you find any bugs or have any suggestions for improvements, feel free to submit an issue or pull request.

About

🦸‍♂️A Deque collection type implemented with Swift's protocols: Sequence, Collection, MutableCollection, and BidirectionalCollection with using of circular buffer to maximize memory usage

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages