aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--challenge-079/abigail/awk/ch-1.awk33
-rw-r--r--challenge-079/abigail/awk/ch-2.awk60
-rwxr-xr-xchallenge-079/abigail/test.pl20
3 files changed, 106 insertions, 7 deletions
diff --git a/challenge-079/abigail/awk/ch-1.awk b/challenge-079/abigail/awk/ch-1.awk
new file mode 100644
index 0000000000..56abe1a74d
--- /dev/null
+++ b/challenge-079/abigail/awk/ch-1.awk
@@ -0,0 +1,33 @@
+#
+# Challenge:
+#
+# You are given a positive number $N.
+#
+# Write a script to count the total numbrer of set bits of the binary
+# representations of all numbers from 1 to $N and return
+# $total_count_set_bit % 1000000007.
+#
+# https://perlweeklychallenge.org/blog/perl-weekly-challenge-079/
+#
+
+#
+# This is A000778 (https://oeis.org/A000788). There's a recursive formala
+# for the number of bits in the binary representation of 0 .. $N:
+#
+# bits (0) = 0
+# bits (2 * N) = bits (N) + bits (N - 1) + N
+# bits (2 * N + 1) = 2 * bits (N) + N + 1
+#
+
+function f(nn, n) {
+ if (nn == 0) {return (0);}
+ if (nn % 2 == 1) {
+ n = (nn - 1) / 2;
+ return 2 * f(n) + n + 1;
+ }
+ n = nn / 2;
+ return f(n) + f(n - 1) + n;
+}
+
+BEGIN {bignum = 1000000007;}
+ {print f($1) % bignum;}
diff --git a/challenge-079/abigail/awk/ch-2.awk b/challenge-079/abigail/awk/ch-2.awk
new file mode 100644
index 0000000000..164dc88b6f
--- /dev/null
+++ b/challenge-079/abigail/awk/ch-2.awk
@@ -0,0 +1,60 @@
+#
+# Challenge:
+#
+# You are given an array of positive numbers @N.
+# Write a script to represent it as Histogram Chart and find out
+# how much water it can trap.
+#
+
+{
+ #
+ # First, find the maximum value.
+ #
+ max = 0;
+ for (i = 1; i <= NF; i ++) {
+ if ($i > max) {
+ max = $i;
+ }
+ }
+
+ #
+ # Given the value, we know how wide every column must be.
+ #
+ format = "%" length (max) "s";
+ show = sprintf (" " format, "#");
+ noshow = sprintf (" " format, " ");
+
+ #
+ # Print the histogram
+ #
+ for (vol = max; vol; vol --) {
+ printf format, vol;
+ for (i = 1; i <= NF; i ++) {
+ if ($i >= vol) {printf show;}
+ else {printf noshow;}
+ }
+ printf "\n";
+ }
+
+ #
+ # Print the line with the bars.
+ #
+ bar = "";
+ for (i = 0; i < length (max); i ++) {
+ bar = bar "_";
+ }
+ printf bar;
+ for (i = 1; i <= NF; i ++) {
+ printf " " bar;
+ }
+ printf "\n";
+
+ #
+ # Print the line with the totals
+ #
+ printf format, " ";
+ for (i = 1; i <= NF; i ++) {
+ printf " " format, $i;
+ }
+ printf "\n";
+}
diff --git a/challenge-079/abigail/test.pl b/challenge-079/abigail/test.pl
index 10eb19dc37..310382b62b 100755
--- a/challenge-079/abigail/test.pl
+++ b/challenge-079/abigail/test.pl
@@ -33,6 +33,11 @@ my %languages = (
ext => "bc",
filter => 's/.*/main($&)/',
},
+ awk => {
+ exe => "/usr/bin/awk",
+ ext => "awk",
+ args => ["-f"],
+ },
);
my $perl_exe = $languages {Perl} {exe};
@@ -41,12 +46,13 @@ foreach my $challenge (1, 2) {
my @inputs = <input-$challenge-*> or next;
subtest "Challenge $challenge" => sub {
foreach my $language (sort keys %languages) {
- my $info = $languages {$language};
- my $exe = $$info {exe};
- my $ext = $$info {ext};
- my $dir = $$info {dir} // lc $language;
- my $filter = $$info {filter} // '';
- my $solution = "$dir/ch-$challenge.$ext";
+ my $info = $languages {$language};
+ my $exe = $$info {exe};
+ my $ext = $$info {ext};
+ my $dir = $$info {dir} // lc $language;
+ my @args = @{$$info {args} // []};
+ my $filter = $$info {filter} // '';
+ my $solution = "$dir/ch-$challenge.$ext";
next unless -r $solution;
subtest $language => sub {
@@ -55,7 +61,7 @@ foreach my $challenge (1, 2) {
my $exp = `cat $output_exp`;
my $got = `$perl_exe -ple '$filter' $input |\
- $exe ./$solution`;
+ $exe @args ./$solution`;
s/\h+$//gm for $exp, $got;
is $got, $exp, $input;