blob: 3caebf28bc60b4857299d53a8ab7a6570f5e54ad (
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
|
#!/usr/bin/env perl
use strict;
use warnings;
use List::Util qw(all);
my $n = 600851475143;
# Functional
# Imperative
my @primes;
my $last_factor;
for my $i (2 .. $n) {
if ($i > $n) {
last;
}
if (all { $i % $_ != 0 } @primes) {
push(@primes, $i);
if ($n % $i== 0) {
$n = $n / $i;
$last_factor = $i;
redo;
}
}
}
print "$last_factor\n";
|