2016-07-29 05:19:01 -04:00
|
|
|
//
|
|
|
|
// Factors.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 29/07/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef Factors_hpp
|
|
|
|
#define Factors_hpp
|
|
|
|
|
2017-08-11 19:18:45 -04:00
|
|
|
#include <numeric>
|
2017-07-21 18:18:45 -04:00
|
|
|
#include <utility>
|
|
|
|
|
2016-07-29 05:19:01 -04:00
|
|
|
namespace NumberTheory {
|
2016-08-01 06:04:55 -04:00
|
|
|
/*!
|
2017-08-11 20:22:14 -04:00
|
|
|
@returns The greatest common divisor of @c a and @c b.
|
2016-08-01 06:04:55 -04:00
|
|
|
*/
|
2016-09-18 10:23:15 -04:00
|
|
|
template<class T> T greatest_common_divisor(T a, T b) {
|
2017-08-11 19:18:45 -04:00
|
|
|
#if __cplusplus > 201402L
|
|
|
|
return std::gcd(a, b);
|
|
|
|
#else
|
2016-09-18 10:23:15 -04:00
|
|
|
if(a < b) {
|
2017-07-21 18:18:45 -04:00
|
|
|
std::swap(a, b);
|
2016-09-18 10:23:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
while(1) {
|
|
|
|
if(!a) return b;
|
|
|
|
if(!b) return a;
|
|
|
|
|
|
|
|
T remainder = a%b;
|
|
|
|
a = b;
|
|
|
|
b = remainder;
|
|
|
|
}
|
2017-08-11 19:18:45 -04:00
|
|
|
#endif
|
2016-09-18 10:23:15 -04:00
|
|
|
}
|
2016-08-01 06:04:55 -04:00
|
|
|
|
|
|
|
/*!
|
2017-08-11 20:22:14 -04:00
|
|
|
@returns The least common multiple of @c a and @c b computed indirectly via the greatest
|
|
|
|
common divisor.
|
2016-08-01 06:04:55 -04:00
|
|
|
*/
|
2016-09-18 10:23:15 -04:00
|
|
|
template<class T> T least_common_multiple(T a, T b) {
|
|
|
|
if(a == b) return a;
|
|
|
|
|
|
|
|
T gcd = greatest_common_divisor<T>(a, b);
|
|
|
|
return (a / gcd) * (b / gcd) * gcd;
|
|
|
|
}
|
2016-07-29 05:19:01 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* Factors_hpp */
|