2020-05-05 06:15:17 +08:00
|
|
|
package Maths;
|
|
|
|
|
|
|
|
/**
|
2020-10-24 18:23:28 +08:00
|
|
|
* Amicable numbers are two different numbers so related that the sum of the proper divisors of each
|
|
|
|
* is equal to the other number. (A proper divisor of a number is a positive factor of that number
|
|
|
|
* other than the number itself. For example, the proper divisors of 6 are 1, 2, and 3.) A pair of
|
|
|
|
* amicable numbers constitutes an aliquot sequence of period 2. It is unknown if there are
|
|
|
|
* infinitely many pairs of amicable numbers. *
|
|
|
|
*
|
|
|
|
* <p>* link: https://en.wikipedia.org/wiki/Amicable_numbers *
|
|
|
|
*
|
|
|
|
* <p>Simple Example : (220,284) 220 is divisible by {1,2,4,5,10,11,20,22,44,55,110 } <- Sum = 284
|
|
|
|
* 284 is divisible by -> 1,2,4,71,142 and the Sum of that is. Yes right you probably expected it
|
|
|
|
* 220
|
2020-05-05 06:15:17 +08:00
|
|
|
*/
|
|
|
|
public class AmicableNumber {
|
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
public static void main(String[] args) {
|
2020-05-05 06:15:17 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
AmicableNumber.findAllInRange(1, 3000);
|
|
|
|
/* Res -> Int Range of 1 till 3000there are 3Amicable_numbers These are 1: = ( 220,284) 2: = ( 1184,1210)
|
|
|
|
3: = ( 2620,2924) So it worked */
|
2020-05-05 06:15:17 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
}
|
2020-05-05 06:15:17 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
/**
|
|
|
|
* @param startValue
|
|
|
|
* @param stopValue
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
static void findAllInRange(int startValue, int stopValue) {
|
2020-05-05 06:15:17 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
/* the 2 for loops are to avoid to double check tuple. For example (200,100) and (100,200) is the same calculation
|
|
|
|
* also to avoid is to check the number with it self. a number with itself is always a AmicableNumber
|
|
|
|
* */
|
|
|
|
StringBuilder res = new StringBuilder();
|
|
|
|
int countofRes = 0;
|
2020-05-05 06:15:17 +08:00
|
|
|
|
2020-10-24 18:23:28 +08:00
|
|
|
for (int i = startValue; i < stopValue; i++) {
|
|
|
|
for (int j = i + 1; j <= stopValue; j++) {
|
|
|
|
if (isAmicableNumber(i, j)) {
|
|
|
|
countofRes++;
|
|
|
|
res.append("" + countofRes + ": = ( " + i + "," + j + ")" + "\t");
|
2020-05-05 06:15:17 +08:00
|
|
|
}
|
2020-10-24 18:23:28 +08:00
|
|
|
}
|
2020-05-05 06:15:17 +08:00
|
|
|
}
|
2020-10-24 18:23:28 +08:00
|
|
|
res.insert(
|
|
|
|
0,
|
|
|
|
"Int Range of "
|
|
|
|
+ startValue
|
|
|
|
+ " till "
|
|
|
|
+ stopValue
|
|
|
|
+ " there are "
|
|
|
|
+ countofRes
|
|
|
|
+ " Amicable_numbers.These are \n ");
|
|
|
|
System.out.println(res.toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if {@code numberOne and numberTwo } are AmicableNumbers or not
|
|
|
|
*
|
|
|
|
* @param numberOne numberTwo
|
|
|
|
* @return {@code true} if {@code numberOne numberTwo} isAmicableNumbers otherwise false
|
|
|
|
*/
|
|
|
|
static boolean isAmicableNumber(int numberOne, int numberTwo) {
|
|
|
|
|
|
|
|
return ((recursiveCalcOfDividerSum(numberOne, numberOne) == numberTwo
|
|
|
|
&& numberOne == recursiveCalcOfDividerSum(numberTwo, numberTwo)));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* calculated in recursive calls the Sum of all the Dividers beside it self
|
|
|
|
*
|
|
|
|
* @param number div = the next to test dividely by using the modulo operator
|
|
|
|
* @return sum of all the dividers
|
|
|
|
*/
|
|
|
|
static int recursiveCalcOfDividerSum(int number, int div) {
|
|
|
|
|
|
|
|
if (div == 1) {
|
|
|
|
return 0;
|
|
|
|
} else if (number % --div == 0) {
|
|
|
|
return recursiveCalcOfDividerSum(number, div) + div;
|
|
|
|
} else {
|
|
|
|
return recursiveCalcOfDividerSum(number, div);
|
2020-05-05 06:15:17 +08:00
|
|
|
}
|
2020-10-24 18:23:28 +08:00
|
|
|
}
|
2020-05-05 06:15:17 +08:00
|
|
|
}
|