Hi,

I have a string and I would like to search for a substring with 0 or 1 mismatch. So, I went ahead and created all possible patterns (so that later I could regexp with foreach over all patterns):

$pattern{$opt_a} = 1; for ($i=0; $i<length($opt_a); $i++) { $prop = $opt_a; substr($prop, $i, 1) = "."; $pattern{$prop}++; }

I have 2 questions about this:

1) Is there an efficient way than this to search for mismatch?

2) If not, is there a possibility to obtain this set of patterns in a more efficient manner rather than using the typical for-loop structure ( I would suppose perl syntaxes enables us to write shorter than say C/C++)?

Thank you!


In reply to generating hash patterns for searching with one mismatch by cedance

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.