#! /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 fds(n) out={} f={1,0} ft={} for i,v in ipairs(f) do ft[v]=true end k=0 while #out < n do j=k ds=0 while j > 0 do ds = ds + j % 10 j=math.floor(j/10) end while f[1] < ds do f[1],f[2]=f[1]+f[2],f[1] ft[f[1]]=true end if ft[ds] ~= nil then table.insert(out,k) end k = k + 1 end return out end if recursive_compare(fds(8),{0, 1, 2, 3, 5, 8, 10, 11}) then io.write("Pass") else io.write("FAIL") end io.write(" ") if recursive_compare(fds(20),{0, 1, 2, 3, 5, 8, 10, 11, 12, 14, 17, 20, 21, 23, 26, 30, 32, 35, 41, 44}) then io.write("Pass") else io.write("FAIL") end io.write(" ") if recursive_compare(fds(61),{0, 1, 2, 3, 5, 8, 10, 11, 12, 14, 17, 20, 21, 23, 26, 30, 32, 35, 41, 44, 49, 50, 53, 58, 62, 67, 71, 76, 80, 85, 94, 100, 101, 102, 104, 107, 110, 111, 113, 116, 120, 122, 125, 131, 134, 139, 140, 143, 148, 152, 157, 161, 166, 170, 175, 184, 193, 200, 201, 203, 206}) then io.write("Pass") else io.write("FAIL") end print("")