Lua比较两个表的值(不考虑键的顺序)
2022-3-5 0:34:24
收藏:0
阅读:4377
评论:1
我在想是否有一种更快的方法来检查两个表是否相等(不考虑键的顺序)。以下是我的解决方案
function TableCompareNoOrder(table1,table2)
if #table1 ~= #table2 then return false end
local equal = false
for key, item in pairs(table1) do
for key2, item2 in pairs(table2) do
if item == item2 then equal = true end
end
if equal == false then return false end
end
local equal = false
for key, item in pairs(table2) do
for key2, item2 in pairs(table1) do
if item == item2 then equal = true end
end
if equal == false then return false end
end
return equal
end
a = {1,2,3,0}
b = {2,3,1,0}
print(TableCompareNoOrder(a,b))
原文链接 https://stackoverflow.com/questions/71357936
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
- 如何编写 Lua 模式将字符串(嵌套数组)转换为真正的数组?
是的,有更快的方法。你现在的方法是O(n²),因为它必须将每个元素与其他元素进行比较。一种方法是先对数组进行排序。另一种方法是使用哈希表创建查找表("set")。如果哈希访问被假定为摊销常数时间,那么这应该以O(n)的时间运行——显着更快。它将需要O(n)额外的内存,但是会保留传递的数组不变;如果使用排序来做同样的事情,你必须先创建一个副本,然后再对其进行排序。
哈希表的方法如下(也适用于像table这样的值,它们是按引用比较的,除非设置metatable或提供自定义比较器函数,否则无法排序):
function TableCompareNoOrder(table1, table2) if #table1 ~= #table2 then return false end -- 如果table1 == table2,则在此处考虑早期的"return true" local t1_counts = {} -- 检查相同的元素出现相同的次数 for _, v1 in ipairs(table1) do t1_counts[v1] = (t1_counts[v1] or 0) + 1 end for _, v2 in ipairs(table2) do local count = t1_counts[v2] or 0 if count == 0 then return false end t1_counts[v2] = count - 1 end return true end
为了完整起见,这里有一个使用排序的简单实现:
function TableCompareNoOrder(table1, table2) if #table1 ~= #table2 then return false end -- 懒惰的实现: 对两个表的副本进行排序,而不是使用二分查找。需要两倍的内存。 local t1_sorted = {table.unpack(table1)} --简单复制表的方法,受堆栈大小限制 table.sort(t1_sorted) local t2_sorted = {table.unpack(table2)} table.sort(t2_sorted) for i, v1 in ipairs(t1_sorted) do if t2_sorted[i] ~= v1 then return false end end return true end
这应该大约运行在O(n log n)的时间复杂度(性能由排序算法决定,通常是快速排序,其平均运行时间为O(n log n))。