#!/usr/bin/perl -w use strict; use Algorithm::Loops 'NestedLoops'; my %f = ( 2 => 2, 3 => 1, 5 => 1, 11 => 1, 277412413 => 1 ); my @f = sort { $b <=> $a } keys %f; my @d = NestedLoops( [ map [ 0 .. $f{$_} ], @f ], sub { my $p = 1; for my $i ( 0 .. $#_ ) { $p *= $f[$i] for 1..$_[$i]; } return $p; }, ); @d = sort { $a <=> $b } @d; print "Divisors: @d\n"; #### Divisors: 1 2 3 4 5 6 10 11 12 15 20 22 30 33 44 55 60 66 110 132 165 220 330 660 277412413 554824826 832237239 1109649652 1387062065 1664474478 2774124130 3051536543 3328948956 4161186195 5548248260 6103073086 8322372390 9154609629 12206146172 15257682715 16644744780 18309219258 30515365430 36618438516 45773048145 61030730860 91546096290 183092192580