-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproblem_36.pl
49 lines (41 loc) · 954 Bytes
/
problem_36.pl
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
use strict;
use warnings;
my @n;
my $d;
my $pal;
sub check_bin_palindrom {
my @bin = split "", sprintf( "%b", $_[0] );
my $i;
for( $i = 0; $i < @bin/2; $i++ ) {
return 0 if( $bin[$i] != $bin[ $#bin - $i ] );
}
return $_[0];
}
my $sum;
foreach my $x (1..999) {
if($x == 1) {
@n = (1,2,3);
$d = 1;
} elsif( $x == 11 ) {
@n = (4,5);
$d = 2;
} elsif( $x == 101 ) {
@n = (6);
$d = 3;
}
foreach my $n (@n) {
if( $n - $d == 0 ) {
$pal = $x;
$sum += check_bin_palindrom( $pal );
} elsif( $n - 2*$d == 0 ) {
$pal = $x . reverse split "", $x;
$sum += check_bin_palindrom( $pal );
} else {
foreach my $m (0..9) {
$pal = $x . $m . reverse split "", $x;
$sum += check_bin_palindrom( $pal );
}
}
}
}
print "Answer: $sum\n";