From ada938bc68fd20a4c41b2c83961a0116d7193c6a Mon Sep 17 00:00:00 2001 From: newt Date: Wed, 9 Oct 2024 18:10:08 +0100 Subject: [PATCH] feat(problem): 3 - largest prime factor --- src/bin/3.rs | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 src/bin/3.rs diff --git a/src/bin/3.rs b/src/bin/3.rs new file mode 100644 index 0000000..6da2da6 --- /dev/null +++ b/src/bin/3.rs @@ -0,0 +1,35 @@ +/* +Problem 3 - Largest prime factor + +The prime factors of 13195 are 5, 7, 13 and 29. +What is the largest prime factor of the number 600851475143 ? +*/ + +fn largest_prime_factor(number: usize) -> usize { + // All even numbers can be divided by 2 + if number % 2 == 0 { + return 2; + } + + let mut i = 3; + let mut num = number.clone(); + let mut primes: Vec = vec![]; + + while num != 1 { + if num % i == 0 { + num /= i; + primes.push(i); + } else { + // Test next odd number + i += 2; + } + } + + // The largest prime factor will be at the end of the vec + return primes[primes.len() - 1]; +} + +fn main() { + let factor = largest_prime_factor(600851475143); + println!("The largest prime factor of 600851475143 is {factor}"); +}