pub fn lcm(nums: &[usize]) -> usize {
if nums.len() == 1 {
return nums[0];
}
let a = nums[0];
let b = lcm(&nums[1..]);
a * b / gcd_of_two_numbers(a, b)
}
fn gcd_of_two_numbers(a: usize, b: usize) -> usize {
if b == 0 {
return a;
}
gcd_of_two_numbers(b, a % b)
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn it_works() {
assert_eq!(lcm(&[1, 2, 3, 4, 5]), 60);
assert_eq!(lcm(&[2, 4, 6, 8, 10]), 120);
assert_eq!(lcm(&[3, 6, 9, 12, 15]), 180);
assert_eq!(lcm(&[10]), 10);
assert_eq!(lcm(&[21, 110]), 2310);
}
}