in reply to Re: combinations of given string
in thread combinations of given string
I can't (yet) work out how to code _next() in Perl.
I like a challenge, but my first try — a one-for-one translation from C into Perl — seems to work fine:
#! perl -slw use strict; permIt(split '', 'ABC---'); sub _next { my ($v) = @_; my $t = ($v | ($v - 1)) + 1; return ($t | (((($t & -$t) / ($v & -$v)) >> 1) - 1)); } sub permIt { my $l = @_; my @chars = grep $_ ne '-', @_; my $n = my $s = (1 << @chars) - 1; do { my $bits = pack 'V', $n; my @copy = @chars; my $str = join '', map { vec( $bits, $_, 1 ) ? shift( @copy ) : '-' } +0 .. $l - 1; print $str; $n = _next($n); } until ($n > ($s << ($l - @chars))); }
Output:
17:18 >perl 760_SoPW.pl ABC--- AB-C-- A-BC-- -ABC-- AB--C- A-B-C- -AB-C- A--BC- -A-BC- --ABC- AB---C A-B--C -AB--C A--B-C -A-B-C --AB-C A---BC -A--BC --A-BC ---ABC 17:18 >perl -v This is perl 5, version 18, subversion 1 (v5.18.1) built for MSWin32-x +86-multi-thread-64int ...
What am I missing?
| Athanasius <°(((>< contra mundum | Iustus alius egestas vitae, eros Piratica, |
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^3: combinations of given string
by BrowserUk (Patriarch) on Oct 26, 2013 at 10:40 UTC | |
by Athanasius (Archbishop) on Oct 26, 2013 at 14:45 UTC | |
by BrowserUk (Patriarch) on Oct 26, 2013 at 17:19 UTC | |
by aitap (Curate) on Oct 26, 2013 at 17:29 UTC | |
by BrowserUk (Patriarch) on Oct 26, 2013 at 22:18 UTC | |
by LanX (Saint) on Oct 27, 2013 at 00:36 UTC |