aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKang-min Liu <gugod@gugod.org>2020-10-07 22:46:49 +0900
committerKang-min Liu <gugod@gugod.org>2020-10-07 22:46:49 +0900
commit1bf08a8547aab0cc7f60923ad26f516afcc6e5ff (patch)
treecf99ff31bdae9aa2bf6057d4fe0b4e07b5d1cd60
parent2bd5f0594278a6086492879b9ff1582e677ca817 (diff)
downloadperlweeklychallenge-club-1bf08a8547aab0cc7f60923ad26f516afcc6e5ff.tar.gz
perlweeklychallenge-club-1bf08a8547aab0cc7f60923ad26f516afcc6e5ff.tar.bz2
perlweeklychallenge-club-1bf08a8547aab0cc7f60923ad26f516afcc6e5ff.zip
solution of 081.2
-rw-r--r--challenge-081/gugod/raku/ch-2.raku28
1 files changed, 28 insertions, 0 deletions
diff --git a/challenge-081/gugod/raku/ch-2.raku b/challenge-081/gugod/raku/ch-2.raku
new file mode 100644
index 0000000000..62a014f118
--- /dev/null
+++ b/challenge-081/gugod/raku/ch-2.raku
@@ -0,0 +1,28 @@
+#!/usr/bin/env raku
+
+sub MAIN (Str $input = 'input') {
+ print-frequency-table( word-frequency( IO::Path.new($input) ) );
+}
+
+sub word-frequency ( $fh ) {
+ my %freq;
+ my $prev = '';
+ for $fh.split(/<?wb>/) -> $token {
+ if $token.match(/<:Letter>/) && !($token eq "s" && $prev eq "'") {
+ %freq{$token} += 1;
+ }
+ $prev = $token;
+ }
+
+ return %freq;
+}
+
+sub print-frequency-table ( %freq ) {
+ my %rfreq;
+ for %freq.pairs -> $it {
+ %rfreq{ $it.value }.append( $it.key );
+ }
+ for %rfreq.keys.sort -> $n {
+ say $n ~ ' ' ~ %rfreq{$n}.sort.join(' ');
+ }
+}