2020-06-06 00:20:25 +08:00
|
|
|
/**
|
|
|
|
* \file
|
2020-09-03 20:52:21 +08:00
|
|
|
* \brief [Problem 5](https://projecteuler.net/problem=5) solution (Fastest).
|
|
|
|
* @details Solution is the LCM of all numbers between 1 and 20.
|
|
|
|
*
|
|
|
|
* \see Slowest: problem_5/sol1.c
|
|
|
|
* \see Slower: problem_5/sol2.c
|
2020-06-06 00:20:25 +08:00
|
|
|
*/
|
2019-10-01 22:21:55 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
|
2020-06-06 00:20:25 +08:00
|
|
|
/** Compute [Greatest Common Divisor
|
|
|
|
* (GCD)](https://en.wikipedia.org/wiki/Greatest_common_divisor) of two numbers
|
|
|
|
* using Euclids algorithm
|
2020-09-03 20:52:21 +08:00
|
|
|
* @param a first number
|
|
|
|
* @param b second number
|
|
|
|
* @return GCD of `a` and `b`
|
2020-06-06 00:20:25 +08:00
|
|
|
*/
|
2020-04-08 21:41:12 +08:00
|
|
|
unsigned long gcd(unsigned long a, unsigned long b)
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
unsigned long r;
|
2020-04-08 21:41:12 +08:00
|
|
|
if (a > b)
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
unsigned long t = a;
|
|
|
|
a = b;
|
|
|
|
b = t;
|
|
|
|
}
|
2020-04-08 21:41:12 +08:00
|
|
|
while ((r = (a % b)))
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
a = b;
|
|
|
|
b = r;
|
|
|
|
}
|
|
|
|
return b;
|
|
|
|
}
|
|
|
|
|
2020-06-06 00:20:25 +08:00
|
|
|
/** Compute [Least Common Multiple
|
|
|
|
* (LCM)](https://en.wikipedia.org/wiki/Least_common_multiple) of two numbers
|
2020-09-03 20:52:21 +08:00
|
|
|
* @param a first number
|
|
|
|
* @param b second number
|
|
|
|
* @return LCM of `a` and `b`
|
2020-06-06 00:20:25 +08:00
|
|
|
*/
|
2020-04-08 21:41:12 +08:00
|
|
|
unsigned long lcm(unsigned long a, unsigned long b)
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
unsigned long long p = (unsigned long long)a * b;
|
|
|
|
return p / gcd(a, b);
|
|
|
|
}
|
|
|
|
|
2020-09-03 20:52:21 +08:00
|
|
|
/** Main function
|
|
|
|
* @returns 0 on exit
|
|
|
|
*/
|
2020-04-08 21:41:12 +08:00
|
|
|
int main(void)
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
unsigned long ans = 1;
|
|
|
|
unsigned long i;
|
2020-04-08 21:41:12 +08:00
|
|
|
for (i = 1; i <= 20; i++)
|
|
|
|
{
|
2019-10-01 22:21:55 +08:00
|
|
|
ans = lcm(ans, i);
|
|
|
|
}
|
|
|
|
printf("%lu\n", ans);
|
|
|
|
return 0;
|
|
|
|
}
|