aboutsummaryrefslogtreecommitdiff
path: root/challenge-113/abigail/lua/ch-1.lua
diff options
context:
space:
mode:
authorLuis Mochan <mochan@fis.unam.mx>2021-05-23 12:11:39 -0500
committerLuis Mochan <mochan@fis.unam.mx>2021-05-23 12:11:39 -0500
commitaf750f6fd9ce9389bd6c12b3aa92fb062451b813 (patch)
treecbe4da14753c7ce57101773e0db98db7785ac890 /challenge-113/abigail/lua/ch-1.lua
parent088dbd3dc9664b07cdf8ab0872c68a903438a0e0 (diff)
parent03eb3fa7435d497e68348362885148da5298156e (diff)
downloadperlweeklychallenge-club-af750f6fd9ce9389bd6c12b3aa92fb062451b813.tar.gz
perlweeklychallenge-club-af750f6fd9ce9389bd6c12b3aa92fb062451b813.tar.bz2
perlweeklychallenge-club-af750f6fd9ce9389bd6c12b3aa92fb062451b813.zip
Merge branch 'master' of github.com:manwar/perlweeklychallenge-club into challenges
Diffstat (limited to 'challenge-113/abigail/lua/ch-1.lua')
-rw-r--r--challenge-113/abigail/lua/ch-1.lua46
1 files changed, 46 insertions, 0 deletions
diff --git a/challenge-113/abigail/lua/ch-1.lua b/challenge-113/abigail/lua/ch-1.lua
new file mode 100644
index 0000000000..4de70d106c
--- /dev/null
+++ b/challenge-113/abigail/lua/ch-1.lua
@@ -0,0 +1,46 @@
+#!/opt/local/bin/lua
+
+--
+-- See ../README.md
+--
+
+--
+-- Run as: lua ch-1.lua < input-file
+--
+
+--
+-- For a description of the algorithm, and the proof why this is correct:
+-- https://abigail.github.io/HTML/Perl-Weekly-Challenge/week-113-1.html
+--
+
+local gcds = {1, 2, 1, 2, 5, 2, 1, 2, 1}
+
+for line in io . lines () do
+ local _, _, N, D = line : find ("([0-9]+)%s+([0-9])")
+ N = tonumber (N)
+ D = tonumber (D)
+ if D == 0
+ then if N >= 100 or N % 10 == 0
+ then print (1)
+ else print (0)
+ end
+ goto end_loop
+ end
+
+ if N >= D * 10
+ then print (1)
+ goto end_loop
+ end
+
+ for i = 0, D / gcds [D] - 1
+ do local T = N - 10 * i - D
+ if T >= 0 and T % D == 0
+ then print (1)
+ goto end_loop
+ end
+ end
+
+ print (0)
+
+ ::end_loop::
+end