forked from TheAlgorithms/Rust
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfactors.rs
46 lines (39 loc) · 1.1 KB
/
factors.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
/// Factors are natural numbers which can divide a given natural number to give a remainder of zero
/// Hence 1, 2, 3 and 6 are all factors of 6, as they divide the number 6 completely,
/// leaving no remainder.
/// This function is to list out all the factors of a given number 'n'
pub fn factors(number: u64) -> Vec<u64> {
let mut factors: Vec<u64> = Vec::new();
for i in 1..((number as f64).sqrt() as u64 + 1) {
if number % i == 0 {
factors.push(i);
if i != number / i {
factors.push(number / i);
}
}
}
factors.sort();
factors
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn prime_number() {
assert_eq!(vec![1, 59], factors(59));
}
#[test]
fn highly_composite_number() {
assert_eq!(
vec![
1, 2, 3, 4, 5, 6, 8, 9, 10, 12, 15, 18, 20, 24, 30, 36, 40, 45, 60, 72, 90, 120,
180, 360
],
factors(360)
);
}
#[test]
fn composite_number() {
assert_eq!(vec![1, 3, 23, 69], factors(69));
}
}