aboutsummaryrefslogtreecommitdiff
path: root/challenge-100/abigail/lua/ch-2.lua
diff options
context:
space:
mode:
author冯昶 <seaker@qq.com>2021-03-15 18:13:51 +0800
committer冯昶 <seaker@qq.com>2021-03-15 18:13:51 +0800
commit8b6be37fe4dac8b4c6489a95e55514b76b298d15 (patch)
treeae36c8ec2c71f606c0e36adaa19dba366a68a0b4 /challenge-100/abigail/lua/ch-2.lua
parent865acfd056fb6f409ec6b1a81d60b931cbcb69fe (diff)
parentc9aec2da6bcb04b488183f09ca94bee488557aff (diff)
downloadperlweeklychallenge-club-8b6be37fe4dac8b4c6489a95e55514b76b298d15.tar.gz
perlweeklychallenge-club-8b6be37fe4dac8b4c6489a95e55514b76b298d15.tar.bz2
perlweeklychallenge-club-8b6be37fe4dac8b4c6489a95e55514b76b298d15.zip
Merge branch 'master' of github.com:seaker/perlweeklychallenge-club
Diffstat (limited to 'challenge-100/abigail/lua/ch-2.lua')
-rw-r--r--challenge-100/abigail/lua/ch-2.lua41
1 files changed, 41 insertions, 0 deletions
diff --git a/challenge-100/abigail/lua/ch-2.lua b/challenge-100/abigail/lua/ch-2.lua
new file mode 100644
index 0000000000..d3e3b3b1d1
--- /dev/null
+++ b/challenge-100/abigail/lua/ch-2.lua
@@ -0,0 +1,41 @@
+#!/opt/local/bin/lua
+
+--
+-- See ../README.md
+--
+
+--
+-- Run as: lua ch-2.lua < input-file
+--
+
+local numbers = {}
+
+--
+-- Read in the data
+--
+for line in io . lines () do
+ local row = {}
+ for n in line : gsub ("\n", "") : gmatch ("-?%d+") do
+ table . insert (row, n)
+ end
+ table . insert (numbers, row)
+end
+
+--
+-- Calculate minimum path, bottom to top
+--
+for x = #numbers - 1, 1, -1 do
+ local row = numbers [x]
+ for y = 1, #row do
+ min = numbers [x + 1] [y]
+ if numbers [x + 1] [y + 1] < min
+ then min = numbers [x + 1] [y + 1]
+ end
+ numbers [x] [y] = numbers [x] [y] + min
+ end
+end
+
+--
+-- Print result
+--
+print (numbers [1] [1])