source code
# The Computer Language Benchmarks Game
# https://salsa.debian.org/benchmarksgame-team/benchmarksgame/
# initial fannkuch port from C by Steve Clark
# rewrite by Kalev Soikonen
# modified by Kuang-che Wu
# modified by David Golden
# updated for fannkuch-redux by Jonathan DePeri
# permutations generated using Mike Pall's approach
use integer;
sub fannkuchredux {
my ($n) = shift;
my ($m, $checksum, $maxflips, $flips, $sign) = ($n-1, 0, 0, 0, 1);
my ($p, $q, $f, $i, @count);
@count = (0..$m);
$p = pack "c*", @count;
do {
if (ord(substr($p,0))) {
$q = $p;
$flips = 0;
while ($f = ord(substr($q,0))) {
$flips++;
substr($q, 0, $f+1, reverse(substr($q,0,$f+1)));
}
$maxflips = $flips if ($flips > $maxflips);
$checksum += ($sign * $flips);
}
return if ($n <= 1);
if ($sign == 1) {
$sign = -1;
substr $p, 1, 0, (substr($p,0,1,""));
} else {
return if ($n <= 2);
$sign = 1;
substr $p, 1, 0, (substr($p,2,1,""));
for $i (2..$m) {
if ($count[$i]) { $count[$i]--; last; }
return ($checksum, $maxflips) if ($i == $m);
$count[$i] = $i;
substr $p, $i+1, 0, (substr($p,0,1,""));
}
}
} while (1);
}
for (shift) {
exit -1 if ((not defined $_) || $_ < 1);
my ($checksum, $maxflips) = fannkuchredux($_);
print "$checksum\n";
print "Pfannkuchen($_) = $maxflips\n";
}
notes, command-line, and program output
NOTES:
64-bit Ubuntu quad core
This is perl 5, version 40
subversion 0 (v5.40.0)
x86_64-linux-thread-multi
Mon, 10 Jun 2024 18:20:54 GMT
COMMAND LINE:
/opt/src/perl-5.40.0/bin/perl fannkuchredux.perl 12
PROGRAM OUTPUT:
3968050
Pfannkuchen(12) = 65