Skip to content

Commit

Permalink
Solution to Euler Project Problem03 (TheAlgorithms#2069)
Browse files Browse the repository at this point in the history
* Solution to Euler Project Problem03

* Solution to Euler Project Problem03
format fix

* format code

* update prime function

Co-authored-by: mickonama <[email protected]>
Co-authored-by: shellhub <[email protected]>
  • Loading branch information
3 people authored Dec 27, 2020
1 parent 95484f8 commit 74b7426
Showing 1 changed file with 62 additions and 0 deletions.
62 changes: 62 additions & 0 deletions ProjectEuler/Problem03.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
package ProjectEuler;

/**
* The prime factors of 13195 are 5, 7, 13 and 29.
*
* <p>What is the largest prime factor of the number 600851475143 ?
*
* <p>Link: https://projecteuler.net/problem=3
*/
public class Problem03 {

/**
* Checks if a number is prime or not
*
* @param n the number
* @return {@code true} if {@code n} is prime
*/
public static boolean isPrime(int n) {
if (n == 2) {
return true;
}
if (n < 2 || n % 2 == 0) {
return false;
}
for (int i = 3, limit = (int) Math.sqrt(n); i <= limit; i += 2) {
if (n % i == 0) {
return false;
}
}
return true;
}

/**
* Calculate all the prime factors of a number and return the largest
*
* @param n integer number
* @return the maximum prime factor of the given number
*/
static long maxPrimeFactor(long n) {
for (int i = 2; i < n / 2; i++) {
if (isPrime(i))
while (n % i == 0) {
n /= i;
}
}
return n;
}

public static void main(String[] args) {
int[][] testNumbers = {
{87, 29},
{10, 5},
{21, 7},
{657, 73},
{777, 37}
};
for (int[] num : testNumbers) {
assert Problem03.maxPrimeFactor(num[0]) == num[1];
}
assert Problem03.maxPrimeFactor(600851475143L) == 6857;
}
}

0 comments on commit 74b7426

Please sign in to comment.