summaryrefslogtreecommitdiff
path: root/020/ch2.pl
blob: d7bbb63d1a45d4622144c0eec8411534b8a31690 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/usr/bin/env perl
#
# Write a script to print the smallest pair of Amicable Numbers. For more
# information, please checkout wikipedia page.
#
# (https://en.wikipedia.org/wiki/Amicable_numbers).
################################################################################

use strict;
use warnings;

sub sum_divisors {
    my $n = shift;
    my $sum = 0;
    foreach my $i (1 .. $n/2) {
        $sum += $i if $n % $i == 0;
    }
    return $sum;
}

my $n1 = 2;
my $n2;
my @already_checked;

while (!$n2) {
    my $sum = sum_divisors($n1);
    if (!grep(/^$sum$/, @already_checked) && $sum != $n1 && sum_divisors($sum) == $n1) {
        $n2 = $sum;
    }
    push @already_checked, $sum, $n1++;
}
$n1--;

print "($n1, $n2)\n";