aboutsummaryrefslogtreecommitdiff
path: root/challenge-093/bkb/test/points.pl
blob: d4168c9a10a01d953c262ff006a4fb1b18731373 (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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#!/home/ben/software/install/bin/perl
use warnings;
use strict;
use utf8;
use FindBin '$Bin';
use JSON::Create;
use JSON::Parse 'parse_json';
use File::Slurper 'write_text';
use IPC::Run3;
use Test::More;

my $binary = "$Bin/../perl/ch1.pl";

my $jc = JSON::Create->new (sort => 1, indent => 1);

# Paolo Custodio

my $paolo1 = ["1 1  2 2  3 4" => {max => 2}];
my $paolo2 = ["1 1  2 2  3 1  1 3  5 3" => {max => 3}];

my $n = 1;
for my $paolo ($paolo1, $paolo2) {
    my $points = $paolo->[0];
    my @n = split /\s+/, $points;
    my @p;
    while (@n) {
	my $p = {};
	$p->{x} = 0 + shift @n;
	$p->{y} = 0 + shift @n;
	push @p, $p;
    }
    run ("paolo-$n", \@p, $paolo->[1]);
    $n++;
}

# Dave Jacoby

my @examples;
push @examples, [ 1, [ [ 1, 1 ], [ 2, 2 ], [ 3, 3 ] ] ];
push @examples, [ 2, [ [ 1, 1 ], [ 2, 2 ], [ 3, 1 ], [ 1, 3 ], [ 5, 3 ] ] ];
push @examples,
    [
    3,
    [ [ 1, 1 ], [ 2, 2 ], [ 3, 1 ], [ 1, 3 ], [ 3, 3 ], [ 4, 4 ], [ 5, 3 ] ]
    ];
push @examples, [ 4, [ [ 1, 2 ], [ 2, 4 ], [ 3, 6 ], [ 4, 8 ] ] ];

# Expected results

my %jx = (
    1 => {max => 3},
    2 => {max => 3},
    3 => {max => 4},
    4 => {max => 4}
);

for my $jacoby (@examples) {
    my $n = $jacoby->[0];
    my @p;
    for my $p (@{$jacoby->[1]}) {
	push @p, {x => $p->[0], y => $p->[1]};
    }
    run ("jacoby-$n", \@p, $jx{$n});
}

# E. Choroba

my @choroba = (
[[[1, 1], [2, 2], [3, 3]], 3, 'Example 1'],
[[[1,1], [2,2], [3,1], [1,3], [5,3]], 3, 'Example 2'],
# The question doesn't really specify whether duplicates are allowed,
# or how to count them if so, so this number is dubious.
# [[[1, 1], [1, 1], [1, 1], [1, 1],
#   [2, 2], [2, 2], [2, 2],
#   [1, 2], [1, 2],
#   [3, 1]],
#  7, 'duplicates'],
[[[2, 2], [3, 2], [4, 2], [5, 2], [5, 3], [6, 7]], 4, 'horizontal'],
[[[2, 2], [2, 3], [2, 4], [2, 5], [5, 3], [6, 7]], 4, 'vertical'],
[[[0, 0], [0, 1], [0, 2],
  [1, 0], [1, 1], [1, 2],
  [2, 0], [2, 1], [2, 2]], 3, '3x3'],
[[[0, 0], [0, 1], [0, 2],
  [1, 0], [1, 1], [1, 2],
  [2, 0], [2, 1], [2, 2],
  [4, 4]], 4, '3x3 diagonal'],
[[[0, 0], [0, 1], [0, 2],
  [1, 0], [1, 1], [1, 2],
  [2, 0], [2, 1], [2, 2],
  [3, 0]], 4, '3x3 horizontal'],
[[[0, 0], [0, 1], [0, 2],
  [1, 0], [1, 1], [1, 2],
  [2, 0], [2, 1], [2, 2],
  [2, 3]], 4, '3x3 vertical'],
);

for my $choroba (@choroba) {
    my @p;
    for (@{$choroba->[0]}) {
	push @p, {x => $_->[0], y => $_->[1]};
    }
    my $name = 'choroba-' . $choroba->[2];
    $name =~ s/\W/-/g;
    run ($name, \@p, {max => $choroba->[1]});
}

done_testing ();
exit;

sub run
{
    my ($name, $input, $expect) = @_;
    my $out = "$Bin/$name.json";
    write_text ($out, $jc->run ($input));
    run3 ("$binary $out", undef, \my $output, \my $errors);
    unlink $out or die $!;
    if ($errors) {
	diag ("Errors from $binary: $errors");
	return;
    }
    my $results = parse_json ($output);
    cmp_ok ($results->{max}, '==', $expect->{max}, "$name count same");
}