aboutsummaryrefslogtreecommitdiff
path: root/challenge-059
diff options
context:
space:
mode:
authorYsmael Ebreo <Ysmael.Ebreo@latticesemi.com>2020-05-04 20:00:41 +0800
committerYsmael Ebreo <Ysmael.Ebreo@latticesemi.com>2020-05-04 20:00:41 +0800
commit733e51221afa9aef20454f07b6639b1f41e24513 (patch)
tree07ac102a2c490127811740cfeb68baa147b3b1fa /challenge-059
parentd6073bcd418a9f9caa7c76d0dd629a10de25837b (diff)
parentc514bff6d2807e124729403c18b4190d251b0e2d (diff)
downloadperlweeklychallenge-club-733e51221afa9aef20454f07b6639b1f41e24513.tar.gz
perlweeklychallenge-club-733e51221afa9aef20454f07b6639b1f41e24513.tar.bz2
perlweeklychallenge-club-733e51221afa9aef20454f07b6639b1f41e24513.zip
Merge branch 'master' of https://github.com/manwar/perlweeklychallenge-club
Diffstat (limited to 'challenge-059')
-rw-r--r--challenge-059/mark-anderson/raku/ch-2.p615
-rw-r--r--challenge-059/simon-proctor/raku/ch-1.raku13
-rw-r--r--challenge-059/wanderdoc/perl/ch-1.pl78
-rw-r--r--challenge-059/wanderdoc/perl/ch-2.pl53
4 files changed, 159 insertions, 0 deletions
diff --git a/challenge-059/mark-anderson/raku/ch-2.p6 b/challenge-059/mark-anderson/raku/ch-2.p6
new file mode 100644
index 0000000000..632161f883
--- /dev/null
+++ b/challenge-059/mark-anderson/raku/ch-2.p6
@@ -0,0 +1,15 @@
+#!/usr/bin/env raku
+
+my @list = (2, 3, 4);
+
+my $sum;
+
+for @list.combinations(2) -> ($n1, $n2) {
+ $sum += f($n1, $n2);
+}
+
+say $sum;
+
+sub f ($n1, $n2) {
+ ($n1 +^ $n2).fmt("%b").comb("1").elems;
+}
diff --git a/challenge-059/simon-proctor/raku/ch-1.raku b/challenge-059/simon-proctor/raku/ch-1.raku
new file mode 100644
index 0000000000..3c485e913a
--- /dev/null
+++ b/challenge-059/simon-proctor/raku/ch-1.raku
@@ -0,0 +1,13 @@
+#!/usr/bin/env raku
+
+use v6;
+
+#| Given an inflaction point and a list of values put all the items less than the inflection point
+#| at the start of the last and all those great or equal after. Retain ordering.
+sub MAIN (
+ Int $inflection, #= Inflection point
+ *@rest where .all ~~ Int #= List of values
+) {
+ my %c = @rest.classify( * >= $inflection );
+ ( |%c{False}, |%c{True} ).say;
+}
diff --git a/challenge-059/wanderdoc/perl/ch-1.pl b/challenge-059/wanderdoc/perl/ch-1.pl
new file mode 100644
index 0000000000..b1fa2ea621
--- /dev/null
+++ b/challenge-059/wanderdoc/perl/ch-1.pl
@@ -0,0 +1,78 @@
+#!perl
+use strict;
+use warnings FATAL => qw(all);
+
+
+
+=prompt
+You are given a linked list and a value k. Write a script to partition the linked list such that all nodes less than k come before nodes greater than or equal to k. Make sure you preserve the original relative order of the nodes in each of the two partitions.
+For example:
+Linked List: 1 → 4 → 3 → 2 → 5 → 2
+k = 3
+Expected Output: 1 → 2 → 2 → 4 → 3 → 5.
+
+=cut
+
+
+my $K = shift || 3;
+my @input = map {(1 .. 10)[rand 10] } 1 .. 10; # (1, 4, 3, 2, 5, 2);
+print join(' -> ', @input), $/;
+
+
+# LL-Implementation.
+# https://www.slideshare.net/lembark/perly-linked-lists
+
+my $list = [[]];
+
+my $node = $list->[0];
+for my $val ( @input )
+{
+ @$node = ([], $val);
+ $node = $node->[0];
+}
+
+my $part_uK = [[]];
+my $node_uK = $part_uK->[0];
+
+my $part_oK = [[]];
+my $node_oK = $part_oK->[0];
+
+
+$node = $list->[0]; # Back to begin.
+
+while ($node)
+{
+ if ( $node->[1] and $node->[1] < $K )
+ {
+ @$node_uK = ([], $node->[1]);
+ $node_uK = $node_uK->[0];
+
+ }
+ elsif ( $node->[1] and $node->[1] >= $K )
+ {
+ @$node_oK = ([], $node->[1]);
+ $node_oK = $node_oK->[0];
+ }
+ $node = $node->[0];
+}
+
+@$node_uK = @{@$part_oK[0]}; # Now all the partitioned LL is in $part_uK.
+# $node_uK was already at the end of the list.
+
+# Free memory.
+undef $list;
+undef $part_oK;
+
+
+
+# Output.
+my $n_all = $part_uK->[0];
+while ( $n_all )
+{
+ print $n_all->[1] if $n_all->[1];
+
+ $n_all = $n_all->[0];
+ print ' -> ' if ($n_all and $n_all->[1]);
+
+}
+print $/; \ No newline at end of file
diff --git a/challenge-059/wanderdoc/perl/ch-2.pl b/challenge-059/wanderdoc/perl/ch-2.pl
new file mode 100644
index 0000000000..e4b5b4b1e4
--- /dev/null
+++ b/challenge-059/wanderdoc/perl/ch-2.pl
@@ -0,0 +1,53 @@
+#!perl
+use strict;
+use warnings FATAL => qw(all);
+
+=prompt
+For this task, you will most likely need a function f(a,b) which returns the count of different bits of binary representation of a and b.
+For example, f(1,3) = 1, since:
+Binary representation of 1 = 01
+Binary representation of 3 = 11
+
+There is only 1 different bit. Therefore the subroutine should return 1. Note that if one number is longer than the other in binary, the most significant bits of the smaller number are padded (i.e., they are assumed to be zeroes).
+Script Output
+
+You script should accept n positive numbers. Your script should sum the result of f(a,b) for every pair of numbers given:
+For example, given 2, 3, 4, the output would be 6, since f(2,3) + f(2,4) + f(3,4) = 1 + 2 + 3 = 6
+
+=cut
+
+use List::Util qw(max);
+
+sub pairwise_difbits
+{
+ my ($n1, $n2) = @_;
+ my $max = max(map length(sprintf("%b", $_)), ($n1, $n2));
+ ($n1, $n2) = map sprintf("%0${max}b", $_) , ($n1, $n2);
+
+ my $count = 0;
+ for my $i ( 0 .. $max - 1 )
+ {
+ $count++ if substr($n1, $i, 1) != substr($n2, $i, 1);
+ }
+ return $count;
+}
+
+sub sumdif
+{
+ my @numbers = @_;
+ my $sum;
+
+
+ for my $i ( 0 .. $#numbers - 1 )
+ {
+ for my $j ( $i .. $#numbers )
+ {
+ next if $i == $j;
+ $sum += pairwise_difbits(@numbers[$i, $j]);
+ }
+ }
+
+ return $sum;
+}
+
+print sumdif ( 1, 2, 3, 4, 5 ), $/; \ No newline at end of file