Beefy Boxes and Bandwidth Generously Provided by pair Networks
Just another Perl shrine

Re^3: string match using with an N in any position

by BrowserUk (Pope)
on Nov 18, 2011 at 05:03 UTC ( #938741=note: print w/replies, xml ) Need Help??

in reply to Re^2: string match using with an N in any position
in thread string match using with an N in any position


During the first iteration, the first of those lines will come down to:

my $matched = ( 'GCGAT' ^ 'GNGAT' ) =~ tr[\0][\0];

In words, the first of the query strings is exclusive-Or'd (^) with the first 5 characters of the first target string.

Where the aligned characters in those two string are the same, the result of xoring them will be zero. Where the two characters differ, the result will be non-zero:

$xord = 'GCGAT' ^ 'GNGAT';; print unpack 'C*', $xord;; 0 13 0 0 0

In order to know how many characters matched, all we need to do is count the zeros, which is efficiently done using the transliteration operator:

$matched = ( 'GCGAT' ^ 'GNGAT' ) =~ tr[\0][\0];; print $matched;; 4

The result of the first line is that $matched is assigned the number of characters that matched between the two strings.

As you want all characters, except one in any position, to match, the second line tests the number that matched against the length of the query string minus 1:

if( $matched >= ( length( $q ) -1 ) ) { ## we have a winner

If you know all your query strings are always five characters, then you could hard code the value 4 instead of ( length( $q ) -1 ). Ditto for the usage of length in the substr, but it never hurts to be flexible if there is little cost involved in doing so.

With the rise and rise of 'Social' network sites: 'Computers are making people easier to use everyday'
Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://938741]
and all is quiet...

How do I use this? | Other CB clients
Other Users?
Others imbibing at the Monastery: (3)
As of 2018-06-23 03:41 GMT
Find Nodes?
    Voting Booth?
    Should cpanminus be part of the standard Perl release?

    Results (125 votes). Check out past polls.