在 LUA 表中查找值
我在 lua g1、g2、g3 中有 3 个表,我正在寻找一种有效的方法来快速找到数字(ID)所在的表,
这就是我到目前为止所拥有的,它看起来效率低下。
g1 = {
37863,
78372,
...
...
}
g2 = {
19599,
84651,
...
...
}
g3 = {
37462,
42843,
...
...
}
for i = 1, 170000 do
if (g1[i] == ID) then
--number found in G1
break
elseif (g2[i] == ID) then
--number found in G2
break
elseif (g3[i] == ID) then
--number found in G3
break
end
end
我能想到的是,我可以重建表格,而不是将数字放在 g 表后面,将其直接放入表格中,如下所示:
g = {
[37863] = 3,
[78372] = 2,
[18788] = 1,
}
if (g[ID] == 1) then
--number found in G1
elseif (g[ID] == 2) then
--number found in G2
elseif (g[ID] == 3) then
--number found in G3
end
您认为可能最有效
I have 3 tables in lua g1, g2, g3 and I'm looking for an efficient way to quickly find which table a number (ID) is in
This is what I have so far and it seems inefficiently slow.
g1 = {
37863,
78372,
...
...
}
g2 = {
19599,
84651,
...
...
}
g3 = {
37462,
42843,
...
...
}
for i = 1, 170000 do
if (g1[i] == ID) then
--number found in G1
break
elseif (g2[i] == ID) then
--number found in G2
break
elseif (g3[i] == ID) then
--number found in G3
break
end
end
what I can think of is that I could reconstruct the tables, instead of putting the number after g table get it directly into the table like this:
g = {
[37863] = 3,
[78372] = 2,
[18788] = 1,
}
if (g[ID] == 1) then
--number found in G1
elseif (g[ID] == 2) then
--number found in G2
elseif (g[ID] == 3) then
--number found in G3
end
what you think might be most effective
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您应该很容易在表上进行测试,无论如何您都应该这样做,但在一般情况下,第二个选项在大型表上进行随机访问会更快。如果您确实总是需要遍历整个列表并将其分成三个存储桶,那么第一个选项可能会更快,这就是为什么您需要在特定用例上测试它。
It should be easy for you to test on your tables, which is what you should do anyway, but in a general case the second option is going to be much faster on large tables for random access. If you do always need to go through the entire list and split it into three buckets, then the first option can be faster and that's why you need to test it on your specific use case.
如果你想收集一个特定的值,你可以简单地迭代你想要搜索的表,我可以给你一个函数来解释你的块。
首先你要做的是创建函数,然后迭代它。扫描主
表
可能有的所有子表,如果找到值:value
,则返回获取该值的路径,否则不返回任何内容。或者对于朋友来说:如果函数返回某些内容,则该值位于其中或某个子表中。
我希望这个结果对您有用,美好的一天!
If you want to collect a specific value you can simple iter the table where you want to search, I can give you a function explaining you the chuncks.
First you do is create the function, and iter it. Scaning all sub-tables may the main
table
have, if the value:value
is found return the path to get the value else return nothing.Or for friends: if the function return something the value is in it or in some sub-table.
I hope this result useful to you, great day!