Processing math: 100%

Brute force

i is a factor of n if n  0 [i], in our case it is enough to iterate over each number. When a factor is found, we simply divide n by that factor and continue as long as n is greater than one. When n is equal to one, we simply return the current factor which is also the largest.

From solution1.py:

def largest_prime_factor(n=600851475143): res = 2 while n != 1: if n % res == 0: n //= res else: res += 1 return res