diff options
| author | Abigail <abigail@abigail.be> | 2021-05-10 21:52:24 +0200 |
|---|---|---|
| committer | Abigail <abigail@abigail.be> | 2021-05-10 21:52:24 +0200 |
| commit | 2292cff0b3bd0bc5e2dadbecee8a4f50cb9fb840 (patch) | |
| tree | ee7581236dbf5ff09d5c0a4ac888a4e4a6038b62 /challenge-112/abigail/node | |
| parent | 5af854f4892557e1f1de653b46402cbfd7baaff9 (diff) | |
| download | perlweeklychallenge-club-2292cff0b3bd0bc5e2dadbecee8a4f50cb9fb840.tar.gz perlweeklychallenge-club-2292cff0b3bd0bc5e2dadbecee8a4f50cb9fb840.tar.bz2 perlweeklychallenge-club-2292cff0b3bd0bc5e2dadbecee8a4f50cb9fb840.zip | |
Node.js solutions for week 112
Diffstat (limited to 'challenge-112/abigail/node')
| -rw-r--r-- | challenge-112/abigail/node/ch-1.js | 28 | ||||
| -rw-r--r-- | challenge-112/abigail/node/ch-2.js | 20 |
2 files changed, 48 insertions, 0 deletions
diff --git a/challenge-112/abigail/node/ch-1.js b/challenge-112/abigail/node/ch-1.js new file mode 100644 index 0000000000..ce79942bfe --- /dev/null +++ b/challenge-112/abigail/node/ch-1.js @@ -0,0 +1,28 @@ +#!/usr/local/bin/node + +// +// See ../README.md +// + +// +// Run as: node ch-1.js < input-file +// + + require ('readline') +. createInterface ({input: process . stdin}) +. on ('line', _ => { + let parts = _ . split (/\/+/) // Split on slash. + let parts2 = [] + parts . every (_ => { + if (_ == "." || _ == "") { // Skip current directory, + return true // and empty parts. + } + if (_ == "..") { // Pop parent directory. + parts2 . pop () + return true + } + parts2 . push (_) // Copy part. + return true + }) + console . log ("/" + parts2 . join ("/")) // Print result. +}) diff --git a/challenge-112/abigail/node/ch-2.js b/challenge-112/abigail/node/ch-2.js new file mode 100644 index 0000000000..aa80e0970d --- /dev/null +++ b/challenge-112/abigail/node/ch-2.js @@ -0,0 +1,20 @@ +#!/usr/local/bin/node + +// +// See ../README.md +// + +// +// Run as: node ch-2.js < input-file +// + +let cache = {0: 1, 1: 1} + +function fib (n) { + cache [n] = cache [n] || fib (n - 1) + fib (n - 2) + return cache [n] +} + + require ('readline') +. createInterface ({input: process . stdin}) +. on ('line', _ => console . log (fib (+ _))) |
