aboutsummaryrefslogtreecommitdiff
path: root/challenge-276/dave-jacoby/perl/ch-2.pl
blob: fc837e272db404b86503c613c4ac6bfc7fe7b273 (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
#!/usr/bin/env perl

use strict;
use warnings;
use experimental qw{ fc say postderef signatures state };

use List::Util qw{ max };

my @examples = (

[1, 2, 2, 4, 1, 5],
[1, 2, 3, 4, 5],
);

for my $input (@examples) {
    my $output = max_freq($input->@*);
    my $ints = join ', ', $input->@*;

    say <<"END";
        Input:  \@ints = ($ints)
        Output: $output
END
}

sub max_freq ( @ints ) {
    my %hash ; 
    map { $hash{$_}++ } @ints;
    my $max = max values %hash;
    my @keys = grep { $hash{$_} == $max } keys %hash;
    return $max * scalar @keys;
}