lua中利用到的排序的基本上就是構造函數(table)了,為了便於和C區分開來,我俗稱它為表單。
實例:(原理就是LUA集成的冒泡算法)
排序的一般姿勢(對於只包含數字或者只包含字符串的簡單數組)
table.sort(test)
擴展版
table.sort(test, function(a,b) return a.id<b.id end )
實例一:值排序
1.數組模式
1 local test0 ={1,9,2,8,3,7,4,6} 2 3 table.sort(test0) --從小到大排序 4 for i,v in pairs(test0) do 5 io.write(v.." ") 6 end 7 print(""); 8 9 table.sort(test0,function(a,b) return a>b end) --從大到小排序 10 for i,v in pairs(test0) do 11 io.write(v.." ") 12 end 13 print(" ")
2.表單模式
local test2 ={ {id=1, name="deng"}, {id=9, name="luo"}, {id=2, name="yang"}, {id=8, name="ma"}, {id=5, name="wu"}, } table.sort(test2,function(a,b) return a.id<b.id end ) for i in pairs(test2) do print(test2[i].id,test2[i].name) end
實例二:鍵值排序
local test1 ={a=1,f=9,d=2,c=8,b=5} local key_test ={} for i in pairs(test1) do table.insert(key_test,i) --提取test1中的鍵值插入到key_test表中 end table.sort(key_test) for i,v in pairs(key_test) do print(v,test1[v]) end