-
-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy pathqueue.rs
91 lines (74 loc) · 2.32 KB
/
queue.rs
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
//! This module provides a generic `Queue` data structure, implemented using
//! Rust's `LinkedList` from the standard library. The queue follows the FIFO
//! (First-In-First-Out) principle, where elements are added to the back of
//! the queue and removed from the front.
use std::collections::LinkedList;
#[derive(Debug)]
pub struct Queue<T> {
elements: LinkedList<T>,
}
impl<T> Queue<T> {
// Creates a new empty Queue
pub fn new() -> Queue<T> {
Queue {
elements: LinkedList::new(),
}
}
// Adds an element to the back of the queue
pub fn enqueue(&mut self, value: T) {
self.elements.push_back(value)
}
// Removes and returns the front element from the queue, or None if empty
pub fn dequeue(&mut self) -> Option<T> {
self.elements.pop_front()
}
// Returns a reference to the front element of the queue, or None if empty
pub fn peek_front(&self) -> Option<&T> {
self.elements.front()
}
// Returns a reference to the back element of the queue, or None if empty
pub fn peek_back(&self) -> Option<&T> {
self.elements.back()
}
// Returns the number of elements in the queue
pub fn len(&self) -> usize {
self.elements.len()
}
// Checks if the queue is empty
pub fn is_empty(&self) -> bool {
self.elements.is_empty()
}
// Clears all elements from the queue
pub fn drain(&mut self) {
self.elements.clear();
}
}
// Implementing the Default trait for Queue
impl<T> Default for Queue<T> {
fn default() -> Queue<T> {
Queue::new()
}
}
#[cfg(test)]
mod tests {
use super::Queue;
#[test]
fn test_queue_functionality() {
let mut queue: Queue<usize> = Queue::default();
assert!(queue.is_empty());
queue.enqueue(8);
queue.enqueue(16);
assert!(!queue.is_empty());
assert_eq!(queue.len(), 2);
assert_eq!(queue.peek_front(), Some(&8));
assert_eq!(queue.peek_back(), Some(&16));
assert_eq!(queue.dequeue(), Some(8));
assert_eq!(queue.len(), 1);
assert_eq!(queue.peek_front(), Some(&16));
assert_eq!(queue.peek_back(), Some(&16));
queue.drain();
assert!(queue.is_empty());
assert_eq!(queue.len(), 0);
assert_eq!(queue.dequeue(), None);
}
}