-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathqueue.rs
More file actions
108 lines (93 loc) · 2.27 KB
/
queue.rs
File metadata and controls
108 lines (93 loc) · 2.27 KB
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
const MAX_QUEUE_SIZE: usize = 10;
// Queue 结构体
struct Queue {
data: Vec<i32>,
size: usize,
}
impl Queue {
// 初始化队列
fn new() -> Self {
Queue {
data: Vec::with_capacity(MAX_QUEUE_SIZE),
size: 0,
}
}
// 判断队列是否为空
fn is_empty(&self) -> bool {
self.size == 0
}
// 判断队列是否已满
fn is_full(&self) -> bool {
self.size == MAX_QUEUE_SIZE
}
// 入队操作
fn enqueue(&mut self, value: i32) {
if self.is_full() {
println!("Queue is full! Cannot enqueue {}", value);
return;
}
self.data.push(value);
self.size += 1;
println!("{} enqueued to queue", value);
}
// 出队操作
fn dequeue(&mut self) -> Option<i32> {
if self.is_empty() {
println!("Queue is empty! Cannot dequeue");
return None;
}
self.size -= 1;
Some(self.data.remove(0))
}
// 获取队头元素
fn peek(&self) -> Option<i32> {
if self.is_empty() {
println!("Queue is empty! Cannot peek");
return None;
}
Some(self.data[0])
}
// 获取队列大小
fn get_size(&self) -> usize {
self.size
}
// 打印队列内容
fn print_queue(&self) {
if self.is_empty() {
println!("Queue is empty");
return;
}
println!("Queue contents: {:?}", self.data);
}
}
fn main() {
let mut queue = Queue::new();
queue.enqueue(10);
queue.enqueue(20);
queue.enqueue(30);
queue.enqueue(40);
queue.enqueue(50);
queue.print_queue();
println!("Dequeued: {:?}", queue.dequeue());
queue.print_queue();
println!("Front element: {:?}", queue.peek());
println!("Queue size: {}", queue.get_size());
queue.enqueue(60);
queue.print_queue();
}
/*
jarry@MacBook-Pro queue % rustc queue.rs
jarry@MacBook-Pro queue % ./queue
10 enqueued to queue
20 enqueued to queue
30 enqueued to queue
40 enqueued to queue
50 enqueued to queue
Queue contents: [10, 20, 30, 40, 50]
Dequeued: Some(10)
Queue contents: [20, 30, 40, 50]
Front element: Some(20)
Queue size: 4
60 enqueued to queue
Queue contents: [20, 30, 40, 50, 60]
*/