diff options
| author | drbaggy <js5@sanger.ac.uk> | 2021-02-11 22:33:34 +0000 |
|---|---|---|
| committer | drbaggy <js5@sanger.ac.uk> | 2021-02-11 22:33:34 +0000 |
| commit | 71be28ef5f9145bcc7b0e25016589ff0ca7159c9 (patch) | |
| tree | aaf5aa8e5e90bbd7f33d9669fe70620c7141829b | |
| parent | 090da47b42eb061cec9f7f395e6aa17fd0b500a1 (diff) | |
| download | perlweeklychallenge-club-71be28ef5f9145bcc7b0e25016589ff0ca7159c9.tar.gz perlweeklychallenge-club-71be28ef5f9145bcc7b0e25016589ff0ca7159c9.tar.bz2 perlweeklychallenge-club-71be28ef5f9145bcc7b0e25016589ff0ca7159c9.zip | |
pushing solutions
| -rw-r--r-- | challenge-099/james-smith/perl/ch-1.pl | 24 | ||||
| -rw-r--r-- | challenge-099/james-smith/perl/ch-2.pl | 56 |
2 files changed, 80 insertions, 0 deletions
diff --git a/challenge-099/james-smith/perl/ch-1.pl b/challenge-099/james-smith/perl/ch-1.pl new file mode 100644 index 0000000000..2f3aad3bfe --- /dev/null +++ b/challenge-099/james-smith/perl/ch-1.pl @@ -0,0 +1,24 @@ +#!/usr/local/bin/perl + +use strict; + +use warnings; +use feature qw(say); +use Test::More; + +is( file_name_match('abcde','a*e'), 1 ); +is( file_name_match('abcde','a*d'), 0 ); +is( file_name_match('abcde','?b*d'), 0 ); +is( file_name_match('abcde','a*c?e'), 1 ); + +done_testing(); + +sub file_name_match { + ## Convert unix file match pattern with perl regex + ## Add beginning end of string anchors \A & \Z to the beginning and end + ## Convert '*' to '.*' & '?' to '.' + ## {use r modifier to return string with replacements in} + my $re = '\A'.($_[1]=~s{[*]}{.*}gr=~s{[?]}{.}gr).'\Z'; + return $_[0] =~ m{$re} ? 1 : 0; +} + diff --git a/challenge-099/james-smith/perl/ch-2.pl b/challenge-099/james-smith/perl/ch-2.pl new file mode 100644 index 0000000000..0fb16e03b1 --- /dev/null +++ b/challenge-099/james-smith/perl/ch-2.pl @@ -0,0 +1,56 @@ +#!/usr/local/bin/perl + +use strict; + +use warnings; +use feature qw(say); +use Test::More; + +my $c ={}; + +is( uniq_subseq('littleit','lit'), 5 ); +is( uniq_subseq('london','lon'), 3 ); +is( uniq_subseq('abc','abc'), 1 ); +is( uniq_subseq('abcabc','abc'), 4 ); +is( uniq_subseq('abcabcabc','abc'), 10 ); +is( uniq_subseq('abcabcabcabc','abc'),20 ); +is( uniq_subseq('abcabcabcabcabc','abc'),35 ); +is( uniq_subseq('abcabcabcabcabcabc','abc'),56 ); +is( uniq_subseq('abcabcabcabcabcabcabc','abc'),84 ); +is( uniq_subseq('abcabcabcabcabcabcabcabc','abc'),120 ); +is( uniq_subseq('abcabcabcabcabcabcabcabcabc','abc'),165 ); + +is( uniq_subseq_cache('littleit','lit'), 5 ); +is( uniq_subseq_cache('london','lon'), 3 ); +is( uniq_subseq_cache('abc','abc'), 1 ); +is( uniq_subseq_cache('abcabc','abc'), 4 ); +is( uniq_subseq_cache('abcabcabc','abc'), 10 ); +is( uniq_subseq_cache('abcabcabcabc','abc'),20 ); +is( uniq_subseq_cache('abcabcabcabcabc','abc'),35 ); +is( uniq_subseq_cache('abcabcabcabcabcabc','abc'),56 ); +is( uniq_subseq_cache('abcabcabcabcabcabcabc','abc'),84 ); +is( uniq_subseq_cache('abcabcabcabcabcabcabcabc','abc'),120 ); +is( uniq_subseq_cache('abcabcabcabcabcabcabcabcabc','abc'),165 ); + +done_testing(); + +sub uniq_subseq { + my( $str, $sub ) = @_; + my $f = substr $sub,0,1,''; + return scalar @{[ $str =~ m{$f}g ]} if $sub eq q(); + my $res = 0; + $res += uniq_subseq($str,$sub) while $str=~s{.*?$f}{}; + return $res; +} + +sub uniq_subseq_cache { + my( $str, $sub ) = @_; + my $k = "$str-$sub"; + return $c->{$k} if exists $c->{$k}; + my $f = substr $sub,0,1,''; + return $c->{$k} = scalar @{[ $str =~ m{$f}g ]} if $sub eq q(); + my $res = 0; + $res += uniq_subseq($str,$sub) while $str=~s{.*?$f}{}; + return $c->{$k} = $res; +} + |
