It would be cool to reuse this regexp search for the forward/backward test, but I don't know how resp. if this is even possible.
If you drop your "without reverse" requirement, you can use it in the regex!
Or, in a more verbose format:/(^.*\z)(?(?{ $+ eq reverse $+ })|(?!))/s
Depending on what you want to match and whether you want backtracking, change the contents of the capture group./ ( # capture group ^ # match begin of string .* # match everything \z # match end of string ) (? # if (?{ $+ eq reverse $+ }) # $+ (last captured group) is palindr +ome # then match nothing (succeed) | # else (?!) # fail on matching nothing (fail the +regex) ) /xs # x for readability, s to make . matc +h \n # Note: can match empty string
I think I prefer Perl 6 regexes here :)
(assuming a \w+ word and no backtracking)rule palindrome { $foo := (\w+) ::: { fail if $foo ne reverse $foo } } # Note: doesn't match empty string
Or a simpler version, but this always backtracks:
Explained:/(.+)(??{ reverse $+ })/s
A Perl 6 version:/ (.+) # match one or more characters (??{ quotemeta reverse $+ }) # match the reverse of what was matc +hed /xs # Note: doesn't match empty string or single character string
rule palindrome { $foo := (\w+) <{ quotemeta reverse $foo }> }
Juerd # { site => 'juerd.nl', plp_site => 'plp.juerd.nl', do_not_use => 'spamtrap' }
In reply to Re: Reverse a Word - without reverse??
by Juerd
in thread Reverse a Word - without reverse??
by PetaMem
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |