2020-06-24 03:33:42 +08:00
|
|
|
/**
|
|
|
|
* @file
|
2023-06-24 04:06:42 +08:00
|
|
|
* @brief A C++ Program to check whether a pair of numbers is an [amicable
|
2020-06-24 03:34:19 +08:00
|
|
|
* pair](https://en.wikipedia.org/wiki/Amicable_numbers) or not.
|
|
|
|
*
|
2023-06-24 04:06:42 +08:00
|
|
|
* @details
|
|
|
|
* An Amicable Pair is two positive integers such that the sum of the proper
|
|
|
|
* divisor for each number is equal to the other number.
|
|
|
|
*
|
|
|
|
* @note Remember that a proper divisor is any positive whole number that
|
|
|
|
* divides into a selected number, apart from the selected number itself, and
|
|
|
|
* returns a positive integer. for example 1, 2 and 5 are all proper divisors
|
|
|
|
* of 10.
|
|
|
|
*
|
|
|
|
* @author [iamnambiar](https://github.com/iamnambiar)
|
2020-06-24 03:33:42 +08:00
|
|
|
*/
|
2023-06-24 04:06:42 +08:00
|
|
|
#include <cassert> /// for assert
|
|
|
|
#include <iostream> /// for IO operations
|
2020-06-24 03:33:42 +08:00
|
|
|
|
|
|
|
/**
|
2023-06-24 04:06:42 +08:00
|
|
|
* @brief Mathematical algorithms
|
|
|
|
* @namespace
|
|
|
|
*/
|
|
|
|
namespace math {
|
|
|
|
/**
|
|
|
|
* @brief Function to calculate the sum of all the proper divisor
|
2020-06-24 03:33:42 +08:00
|
|
|
* of an integer.
|
2023-06-24 04:06:42 +08:00
|
|
|
* @param num selected number.
|
2020-06-24 03:33:42 +08:00
|
|
|
* @return Sum of the proper divisor of the number.
|
|
|
|
*/
|
|
|
|
int sum_of_divisor(int num) {
|
|
|
|
// Variable to store the sum of all proper divisors.
|
2023-06-24 04:06:42 +08:00
|
|
|
int sum = 1;
|
2020-06-24 03:34:19 +08:00
|
|
|
// Below loop condition helps to reduce Time complexity by a factor of
|
|
|
|
// square root of the number.
|
2020-06-24 03:33:42 +08:00
|
|
|
for (int div = 2; div * div <= num; ++div) {
|
|
|
|
// Check 'div' is divisor of 'num'.
|
|
|
|
if (num % div == 0) {
|
|
|
|
// If both divisor are same, add once to 'sum'
|
|
|
|
if (div == (num / div)) {
|
|
|
|
sum += div;
|
|
|
|
} else {
|
|
|
|
// If both divisor are not the same, add both to 'sum'.
|
|
|
|
sum += (div + (num / div));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-06-24 04:06:42 +08:00
|
|
|
return sum;
|
2020-06-24 03:33:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-06-24 04:06:42 +08:00
|
|
|
* @brief Function to check whether the pair is amicable or not.
|
2020-06-24 03:33:42 +08:00
|
|
|
* @param x First number.
|
|
|
|
* @param y Second number.
|
|
|
|
* @return `true` if the pair is amicable
|
|
|
|
* @return `false` if the pair is not amicable
|
|
|
|
*/
|
|
|
|
bool are_amicable(int x, int y) {
|
|
|
|
return (sum_of_divisor(x) == y) && (sum_of_divisor(y) == x);
|
|
|
|
}
|
2023-06-24 04:06:42 +08:00
|
|
|
} // namespace math
|
2020-06-24 03:33:42 +08:00
|
|
|
|
|
|
|
/**
|
2023-06-24 04:06:42 +08:00
|
|
|
* @brief Self-test implementations
|
|
|
|
* @returns void
|
2020-06-24 03:33:42 +08:00
|
|
|
*/
|
2023-06-24 04:06:42 +08:00
|
|
|
static void tests() {
|
|
|
|
assert(math::are_amicable(220, 284) == true);
|
|
|
|
assert(math::are_amicable(6368, 6232) == true);
|
|
|
|
assert(math::are_amicable(458, 232) == false);
|
|
|
|
assert(math::are_amicable(17296, 18416) == true);
|
|
|
|
assert(math::are_amicable(18416, 17296) == true);
|
|
|
|
|
|
|
|
std::cout << "All tests have successfully passed!" << std::endl;
|
2020-06-24 03:33:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-06-24 04:06:42 +08:00
|
|
|
* @brief Main function
|
|
|
|
* @returns 0 on exit
|
2020-06-24 03:34:19 +08:00
|
|
|
*/
|
2020-06-24 03:33:42 +08:00
|
|
|
int main() {
|
2023-06-24 04:06:42 +08:00
|
|
|
tests(); // perform self-tests implementations
|
2020-06-24 03:33:42 +08:00
|
|
|
return 0;
|
|
|
|
}
|