aboutsummaryrefslogtreecommitdiff
path: root/challenge-080/roger-bell-west/perl/ch-2.pl
blob: c0a92585e6782d40f6ddaaa235815c52d8a9cd38 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#! /usr/bin/perl

use strict;
use warnings;

use List::Util qw(max sum);

use Test::More tests => 2;

is(cc([1,2,2]),4,'example 1');
is(cc([1,4,3,2]),7,'example 2');

sub cc {
  my @list=@{shift @_};
  my @n=sort {$list[$a] <=> $list[$b]} (0..$#list);
  my @k;
  foreach my $i (@n) {
    my @nr=(1);
    if ($i > 0 && $list[$i-1] < $list[$i]) {
      if (defined $k[$i-1]) {
        push @nr,$k[$i-1]+1;
      }
    }
    if ($i < $#list && $list[$i+1] < $list[$i]) {
      if (defined $k[$i+1]) {
        push @nr,$k[$i+1]+1;
      }
    }
    $k[$i]=max(@nr);
  }
  return sum(@k);
}