微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

lua的table排序

实例:(原理就是LUA集成的冒泡算法)

--排序的算法
function comps(a,b)
return a.id < b.id
end

--应用
table.sort(table_name,comps);

table_name 已经被修改


一、数值数组排序(字符串跟数值混在一起的数组是不能sort的)

[plain]  view plain copy
  1. local test_table = {2,1,3}  
  2. table.sort(test_table)  
  3. for key,value in pairs(test_table) do  
  4.     print(key,value)  
  5. end  

输出结果:

copy
    >lua -e "io.stdout:setvbuf 'no'" "test.lua"  
  1. 1   1  
  2. 2   2  
  3. 3   3  
二、字符串数组排序

copy
    local test_table = {"a","c","b"}  
  1. end  
输出结果:
copy
    1   a  
  1. 2   b  
  2. 3   c  
三、键值对Table排序(按Key排序,不是Value
copy
    local test_table = {a=3,b=2,c=4,d=1}  
  1. local key_table = {}  
  2. --取出所有的键  
  3. for key,_ in pairs(test_table) do  
  4.     table.insert(key_table,key)  
  5. end  
  6. --对所有键进行排序  
  7. table.sort(key_table)  
  8. for _,key in pairs(key_table) do  
  9. copy
    1. a   3  
    2. b   2  
    3. c   4  
    4. d   1  

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐