aboutsummaryrefslogtreecommitdiff
path: root/challenge-159/roger-bell-west/lua
diff options
context:
space:
mode:
authorPaulo Custodio <pauloscustodio@gmail.com>2022-04-12 18:56:29 +0100
committerPaulo Custodio <pauloscustodio@gmail.com>2022-04-12 18:56:29 +0100
commit49f7f459092f538b5468e255ff4e8ebac490d70a (patch)
treefa4a94a8207a58a56d4dca98ff22d39bed047f6e /challenge-159/roger-bell-west/lua
parent1711da4f548d3134248cd5e02a13d71762d5e4cb (diff)
parent72ba70a96cfd587443c3eaa0f5ba02e3557f4b82 (diff)
downloadperlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.tar.gz
perlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.tar.bz2
perlweeklychallenge-club-49f7f459092f538b5468e255ff4e8ebac490d70a.zip
Merge remote-tracking branch 'upstream/master'
# Conflicts: # challenge-160/paulo-custodio/Makefile
Diffstat (limited to 'challenge-159/roger-bell-west/lua')
-rwxr-xr-xchallenge-159/roger-bell-west/lua/ch-1.lua104
-rwxr-xr-xchallenge-159/roger-bell-west/lua/ch-2.lua97
2 files changed, 201 insertions, 0 deletions
diff --git a/challenge-159/roger-bell-west/lua/ch-1.lua b/challenge-159/roger-bell-west/lua/ch-1.lua
new file mode 100755
index 0000000000..d10299f584
--- /dev/null
+++ b/challenge-159/roger-bell-west/lua/ch-1.lua
@@ -0,0 +1,104 @@
+#! /usr/bin/lua
+
+-- by Michael Anderson at
+-- https://stackoverflow.com/questions/8722620/comparing-two-index-tables-by-index-value-in-lua
+function recursive_compare(t1,t2)
+ -- Use usual comparison first.
+ if t1==t2 then return true end
+ -- We only support non-default behavior for tables
+ if (type(t1)~="table") then return false end
+ -- They better have the same metatables
+ local mt1 = getmetatable(t1)
+ local mt2 = getmetatable(t2)
+ if( not recursive_compare(mt1,mt2) ) then return false end
+
+ -- Check each key-value pair
+ -- We have to do this both ways in case we miss some.
+ -- TODO: Could probably be smarter and not check those we've
+ -- already checked though!
+ for k1,v1 in pairs(t1) do
+ local v2 = t2[k1]
+ if( not recursive_compare(v1,v2) ) then return false end
+ end
+ for k2,v2 in pairs(t2) do
+ local v1 = t1[k2]
+ if( not recursive_compare(v1,v2) ) then return false end
+ end
+
+ return true
+end
+
+function gcd(m0,n0)
+ local m,n = m0,n0
+ while n ~= 0 do
+ m,n = n,m % n
+ end
+ return m
+end
+
+function lcm(m,n)
+ return m/gcd(m,n)*n
+end
+
+function lcmseries(a,b)
+ local t=1
+ for v = a,b do
+ t = lcm(t,v)
+ end
+ return t
+end
+
+function farey(n)
+ local l=lcmseries(2,n)
+ local d={}
+ local s={}
+ for i = 1,n do
+ local m = l / i
+ for j = 0,i do
+ local k = m * j
+ if d[k] == nil then
+ d[k] = {j,i}
+ table.insert(s,k)
+ end
+ end
+ end
+ table.sort(s)
+ local out={}
+ for k,v in ipairs(s) do
+ table.insert(out,d[v])
+ end
+ return out
+end
+
+if recursive_compare(farey(5),{
+ {0, 1}, {1, 5}, {1, 4}, {1, 3}, {2, 5},
+ {1, 2}, {3, 5}, {2, 3}, {3, 4}, {4, 5},
+ {1, 1}
+ }) then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+io.write(" ")
+
+if recursive_compare(farey(7),{
+ {0, 1}, {1, 7}, {1, 6}, {1, 5}, {1, 4},
+ {2, 7}, {1, 3}, {2, 5}, {3, 7}, {1, 2},
+ {4, 7}, {3, 5}, {2, 3}, {5, 7}, {3, 4},
+ {4, 5}, {5, 6}, {6, 7}, {1, 1}
+ }) then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+io.write(" ")
+
+if recursive_compare(farey(4),{
+ {0, 1}, {1, 4}, {1, 3}, {1, 2}, {2, 3},
+ {3, 4}, {1, 1}
+ }) then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+print("")
diff --git a/challenge-159/roger-bell-west/lua/ch-2.lua b/challenge-159/roger-bell-west/lua/ch-2.lua
new file mode 100755
index 0000000000..1e79067d53
--- /dev/null
+++ b/challenge-159/roger-bell-west/lua/ch-2.lua
@@ -0,0 +1,97 @@
+#! /usr/bin/lua
+
+function genprimes(mx)
+ local primesh = {}
+ for i = 2, 3 do
+ primesh[i] = true
+ end
+ for i = 6, mx, 6 do
+ for j = i-1, i+1, 2 do
+ if j <= mx then
+ primesh[j]=true
+ end
+ end
+ end
+ local q={2,3,5,7}
+ local p=table.remove(q,1)
+ local mr=math.floor(math.sqrt(mx))
+ while p <= mr do
+ if primesh[p] ~= nil then
+ for i = p*p,mx,p do
+ primesh[i] = nil
+ end
+ end
+ if #q < 2 then
+ table.insert(q,q[#q]+4)
+ table.insert(q,q[#q]+2)
+ end
+ p=table.remove(q,1)
+ end
+ local primes = {}
+ for k,v in pairs(primesh) do
+ table.insert(primes,k)
+ end
+ table.sort(primes)
+ return primes
+end
+
+function primefactor(n)
+ local f={}
+ local m=n
+ for k,p in pairs(genprimes(math.floor(math.sqrt(m)))) do
+ while m % p == 0 do
+ m=math.floor(m/p)
+ if f[p] == nil then
+ f[p]=1
+ else
+ f[p] = f[p] + 1
+ end
+ if m==1 then
+ break
+ end
+ end
+ end
+ if m>1 then
+ if f[m] == nil then
+ f[m]=1
+ else
+ f[m] = f[m] + 1
+ end
+ end
+ return f
+end
+
+function moebius(n)
+ local z=0
+ for k,v in pairs(primefactor(n)) do
+ if v > 1 then
+ return 0
+ end
+ z = z + 1
+ end
+ if z % 2 == 0 then
+ return 1
+ end
+ return -1
+end
+
+if moebius(5) == -1 then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+io.write(" ")
+
+if moebius(10) == 1 then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+io.write(" ")
+
+if moebius(20) == 0 then
+ io.write("Pass")
+else
+ io.write("FAIL")
+end
+print("")