Using a
delayed execution assertion, typically used to create recursively matching regexes, I came up with this:
my $re;
$re = qr/((.)(??{ $re })\2|.)/;
my $s = 'abcdegedfc';
foreach my $i (0 .. length($s) - 1) {
local $\ = "\n"; # add newline to print
substr($s, $i) =~ /^$re/ and print $1;
}
I need a loop, because the regex by itself doesn't search for the longest palindrome, so I added a
/^/ anchor to avoid any potential, useless backtacking. It doesn't actually chnage the result.
This little program prints:
a
b
c
deged
ege
g
e
d
f
c
So all you still have to do, is keep the longest match from the loops.
update: I found a second working regex, inspired by holli who came up with the idea to use reverse:
my $s = 'abcdegedfc';
foreach my $i (0 .. length($s) - 1) {
local $\ = "\n"; # add newline to print
substr($s, $i) =~ /((.*).?(??{ quotemeta reverse $2 }))/
and print $1;
}
Output is identical to the previous program.
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.