diff options
| author | Luis Mochan <mochan@fis.unam.mx> | 2021-05-23 12:11:39 -0500 |
|---|---|---|
| committer | Luis Mochan <mochan@fis.unam.mx> | 2021-05-23 12:11:39 -0500 |
| commit | af750f6fd9ce9389bd6c12b3aa92fb062451b813 (patch) | |
| tree | cbe4da14753c7ce57101773e0db98db7785ac890 /challenge-113/abigail/lua/ch-1.lua | |
| parent | 088dbd3dc9664b07cdf8ab0872c68a903438a0e0 (diff) | |
| parent | 03eb3fa7435d497e68348362885148da5298156e (diff) | |
| download | perlweeklychallenge-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.lua | 46 |
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 |
