Here is a simple way to do it by keeping track of how deep you are into parenthesis' and what depth your match occured at:
use strict;
my $str = "((A,B),C,(D,E))";
foreach my $m (qw(A B C D E)) {
print $m." => ".FindMinParens($m,$str)."\n";
}
sub FindMinParens{
my $match = shift;
my $string = shift;
my @start_pos;
my $depth = -1;
# keep matching parens or $match
while ($string=~/([()]|$match)/g) {
if ($1 eq "(") {
# record opening paren positions
push @start_pos,pos($string);
}
elsif ($1 eq ")") {
# if we reached the closing parens for the minimum pair
# get the sub string and exit
if ($#start_pos == $depth) {
my $start = $start_pos[-1];
my $len = pos($string) - $start -1;
return substr($string,$start,$len);
}else{
pop @start_pos;
}
}
else {
# store depth of $match
$depth = $#start_pos;
}
}
return "";
}
__OUTPUT__
A => A,B
B => A,B
C => (A,B),C,(D,E)
D => D,E
E => D,E
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: |
| & | | & |
| < | | < |
| > | | > |
| [ | | [ |
| ] | | ] |
Link using PerlMonks shortcuts! What shortcuts can I use for linking?
See Writeup Formatting Tips and other pages linked from there for more info.