This problem is making a program to find the largest prime factor for a given number.
In fact, no choice but to use the body of elastomer Ness Te find the largest prime factor.
It is one that is required is to continue to divide a given number. Is beyond the scope of this program as well.
The general form for a small number of bit to speed, all except 2 is an odd prime number.
Is an odd prime factor is to reduce the number of attempts and the like has a 6k + 1, 6k + 5 is.
Well, not like this time by a more efficient method for finding algorithm.
Simply squeeze the program look as follows:
int main() { int p = 3; int64 n = 600851475143; while( n%2 == 0 ) n /= 2; if( n == 1 ) { printf("Ans = 2\n"); return 0; } while( 1 ) { while( n%p == 0 ) n /= p; if( n == 1 ) break; p += 2; } printf("Ans = %d\n", p); return 0; }
'Programming > Project Euler' 카테고리의 다른 글
5. Project Euler #5 : The smallest number that can be divided by numbers below 20. (0) | 2015.01.29 |
---|---|
4. Project Euler #4 : Largest palindrome product. (0) | 2015.01.22 |
[C/C++] Project Euler #2 : Sum of even terms of Fibonacci(Dynamic Programming) (0) | 2015.01.20 |
[C/C++] Project Euler #1 Add 3 or 5 multipliers. (0) | 2015.01.19 |
Project Euler #0 : start up. (0) | 2015.01.19 |