-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy paths0379_design_phone_directory.rs
More file actions
63 lines (56 loc) · 1.61 KB
/
s0379_design_phone_directory.rs
File metadata and controls
63 lines (56 loc) · 1.61 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
#![allow(unused)]
struct PhoneDirectory {
next: Vec<i32>,
pos: usize,
}
/**
* `&self` means the method takes an immutable reference.
* If you need a mutable reference, change it to `&mut self` instead.
*/
impl PhoneDirectory {
/** Initialize your data structure here
@param maxNumbers - The maximum numbers that can be stored in the phone directory. */
fn new(max_numbers: i32) -> Self {
let mut next = vec![];
for i in 0..max_numbers {
next.push((i + 1) % max_numbers);
}
Self { next, pos: 0 }
}
/** Provide a number which is not assigned to anyone.
@return - Return an available number. Return -1 if none is available. */
fn get(&mut self) -> i32 {
if self.next[self.pos] == -1 {
return -1;
}
let ret = self.pos;
self.pos = self.next[self.pos] as usize;
self.next[self.pos] = -1;
return ret as i32;
}
/** Check if a number is available or not. */
fn check(&self, number: i32) -> bool {
self.next[number as usize] == -1
}
/** Recycle or release a number. */
fn release(&mut self, number: i32) {
if self.next[number as usize] != -1 {
return;
}
self.next[number as usize] = self.pos as i32;
self.pos = number as usize;
}
}
/**
* Your PhoneDirectory object will be instantiated and called as such:
* let obj = PhoneDirectory::new(maxNumbers);
* let ret_1: i32 = obj.get();
* let ret_2: bool = obj.check(number);
* obj.release(number);
*/
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_346() {}
}