neversaint,
Here is another solution that might should be more efficient than the one above. This solution only generates strings that are desired neighbor. Explanation for how it does that are in the comments.
#!/usr/bin/perl use strict; use warnings; use Algorithm::Loops 'NestedLoops'; # This solution says take all possible pairs of indices # Then count in base 4, replacing the value at that index my $input = $ARGV[0] || '000'; my @seed = split //, $input; # Don't replace two values with exact same two values my %seen; my $idx_iter = combo(2, 0 .. $#seed); while (my @idx = $idx_iter->()) { my $base4_iter = NestedLoops([([0..3]) x 2]); while (my @base4 = $base4_iter->()) { my @neighbor = @seed; @neighbor[@idx] = @base4; print "@neighbor\n" if ! $seen{"@neighbor"}++; } } # Taken from [id://393064] sub combo { my $by = shift; return sub { () } if ! $by || $by =~ /\D/ || @_ < $by; my @list = @_; my @position = (0 .. $by - 2, $by - 2); my @stop = @list - $by .. $#list; my $end_pos = $#position; my $done = undef; return sub { return () if $done; my $cur = $end_pos; { if ( ++$position[ $cur ] > $stop[ $cur ] ) { $position[ --$cur ]++; redo if $position[ $cur ] > $stop[ $cur ]; my $new_pos = $position[ $cur ]; @position[ $cur .. $end_pos ] = $new_pos .. $new_pos + + $by; } } $done = 1 if $position[0] == $stop[0]; return @list[ @position ]; } }

Cheers - L~R


In reply to Re: Finding String's Neighbors By Up To 2 Differing Positions by Limbic~Region
in thread Finding String's Neighbors By Up To 2 Differing Positions by neversaint

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.