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
|
#!/usr/bin/env perl
use strict;
use warnings;
my @numbers = ( 2, 4, 3 );
print("numbers: @numbers\n");
my @n = sort @numbers;
my @pair = ();
for my $i (0 .. $#n) {
for my $j ($i .. $#n) {
push @pair, [ $n[$i] , $n[$j] ] unless $n[$i] eq $n[$j];
}
}
my $bit_sum = 0;
for my $pair (@pair) {
my $binA = sprintf("%032b", $pair->[0]);
my $binB = sprintf("%032b", $pair->[1]);
my @binA = split '', $binA;
my @binB = split '', $binB;
my $diff = 0;
for my $idx (0.. $#binA) {
$diff++ if $binA[$idx] != $binB[$idx];
}
printf "%s = %s\n%s = %s\n", $binA, $pair->[0], $binB,$pair->[1];
printf "f(%s, %s) = %s\n\n", $pair->[0], $pair->[1], $diff;
$bit_sum += $diff;
}
print "bit sum = $bit_sum\n";
|