1. Introduction
A PriorityQueue is a special type of queue in which each element has a priority. Elements with higher priorities are served before elements with lower priorities. This data structure is useful in scenarios where not all items are equal and certain items must be processed before others, such as in job scheduling or graph algorithms.
2. Implementation Steps
1. Define a PriorityQueue class or struct.
2. Use a private array to store the elements of the priority queue.
3. Define a method enqueue to add an item with a given priority.
4. Define a method dequeue to remove the item with the highest priority.
5. Provide a method peek to view the highest priority item without removing it.
6. Include a computed property isEmpty to check if the priority queue is empty.
3. Implementation in Swift
struct PriorityQueue<T> {
private var elements: [(value: T, priority: Int)] = []
// Enqueue: Add an item with a given priority
mutating func enqueue(_ value: T, priority: Int) {
elements.append((value, priority))
elements.sort { $0.priority > $1.priority }
}
// Dequeue: Remove and return the highest priority item
mutating func dequeue() -> T? {
return isEmpty ? nil : elements.removeFirst().value
}
// Peek: Look at the highest priority item without removing it
func peek() -> T? {
return elements.first?.value
}
// Check if the priority queue is empty
var isEmpty: Bool {
return elements.isEmpty
}
}
// Example Usage
var tasks = PriorityQueue<String>()
tasks.enqueue("Regular task", priority: 1)
tasks.enqueue("High priority task", priority: 3)
tasks.enqueue("Medium priority task", priority: 2)
print("After enqueues: \(tasks)")
print("Peek: \(tasks.peek() ?? "None")")
print("Dequeue: \(tasks.dequeue() ?? "None")")
print("After dequeue: \(tasks)")
Output:
After enqueues: PriorityQueue<String>(elements: [("High priority task", 3), ("Medium priority task", 2), ("Regular task", 1)])
Peek: High priority task
Dequeue: High priority task
After dequeue: PriorityQueue<String>(elements: [("Medium priority task", 2), ("Regular task", 1)])
Explanation:
1. A PriorityQueue is implemented as a generic struct. Each element in the queue is represented as a tuple containing a value and its associated priority.
2. Within the PriorityQueue, a private array named elements is used to manage the elements.
3. The enqueue method appends an item with its given priority to the elements array. The elements are then sorted in descending order based on priority.
4. The dequeue method removes and returns the first item (highest priority) from the elements array. If the priority queue is empty, it returns nil.
5. The peek method provides a way to view the highest priority item without removing it.
6. The isEmpty computed property checks if the elements array is empty, indicating the state of the priority queue.
DSA
Related Swift Examples:
Swift Hello World Program
Swift Program to Add Two Numbers
Swift Program to Subtract Two Numbers
Swift Program to Multiply Two Numbers
Swift Program to Divide Two Numbers
Swift Program to Find Remainder
Swift Program to Check Even or Odd
Swift Program to Find Factorial of a Number
Swift Program to Generate Fibonacci Series
Swift Program to Swap Two Numbers Without Using Temporary Variable
Swift Program to Find Largest Among Three Numbers
Swift Program to Calculate the Area of a Circle
Swift Program to Reverse a Number
Swift Program to Make a Simple Calculator
Swift Program to Check Palindrome
Swift Program to Count Number of Digits in an Integer
Swift Program to Sum of Natural Numbers
Swift Program to Display Times Table
Swift Program to Check Prime Number
Swift Program to Find LCM
Swift Program to Find GCD
Swift Program to Find the Power of a Number
Swift Program to Split a String into Words
Swift Program to Check Leap Year
Swift Program to Join Two Strings
Swift Program to Check Armstrong Number
Swift Program to Find Sum of Array Elements
Swift Program to Find the Largest Element of an Array
Swift Program to Perform Matrix Addition
Swift Program to Transpose a Matrix
Swift Program to Multiply Two Matrices
Swift Program to Find Length of a String
Swift Program to Copy One String to Another String
Swift Program to Concatenate Two Strings
Swift Program to Search for a Character in a String
Swift Program to Count Frequency of a Character in String
Swift Program to Create a Simple Class and Object
Swift Program to Implement Inheritance
Swift Program to Handle Simple Exceptions
Swift Variables and Constants Example
Swift Data Types (Int, Double, String) Example
Swift Optionals and Optional Binding Example
Swift Tuples Example
Swift Array Example
Swift Dictionary Example
Swift Set Example
Swift Closures Example
Swift Enums Example
Swift Structures Example
Swift Properties (Stored, Computed) Example
Swift Methods (Instance, Type) Example
Swift Subscripts Example
Swift Inheritance and Overriding Example
Swift Protocols Example
Swift Extensions Example
Swift Generics and Generic Functions Example
Swift Error Handling with Do-Catch Example
Swift Guard Statement Example
Swift Defer Statement Example
Swift Type Casting (as, is, as?) Example
Swift Access Control Example
Swift Attributes (@available, @discardableResult) Example
Swift Pattern Matching Example
Swift Switch Statement and Cases Example
Swift For-In Loop Example
Swift While and Repeat-While Loops Example
Swift Conditional Statements (If, If-Else, Ternary) Example
Swift Operators Example
Swift Memory Management Example
Swift Strong, Weak, and Unowned References Example
Swift Initialization and Deinitialization Example
Swift Protocol-Oriented Programming Example
Swift Nested Types Example
Swift Type Aliases Example
Swift Dynamic Member Lookup Example
Swift Lazy Stored Properties Example
Swift KeyPaths Example
Swift String Manipulation and Methods Example
Swift Regular Expressions Example
Swift
Comments
Post a Comment