lua的table排序


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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM