欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Lua學(xué)習(xí)筆記之?dāng)?shù)據(jù)結(jié)構(gòu)

 更新時間:2014年09月11日 12:42:33   作者:皂莢花  
這篇文章主要介紹了Lua學(xué)習(xí)筆記之?dāng)?shù)據(jù)結(jié)構(gòu),本文講解了數(shù)組、矩陣、鏈表、隊列等內(nèi)容,需要的朋友可以參考下

最近研究Lua,順便寫點筆記吧!數(shù)據(jù)結(jié)構(gòu)是沒有語言之分的,只不過不同的語言實現(xiàn)起來的語法不同,既然是Lua菜鳥,就來實現(xiàn)幾個常用的數(shù)據(jù)結(jié)構(gòu)來練練語法吧!首先是作為數(shù)據(jù)結(jié)構(gòu)基石的數(shù)組,在Lua中數(shù)組是用表來實現(xiàn)的,表是個強大的東西,能表示太多東西了,當(dāng)表中元素的下標(biāo)都是整數(shù)的時候,我們把這個表稱作數(shù)組。數(shù)組的大小不固定,可以動態(tài)的增長。

復(fù)制代碼 代碼如下:

--創(chuàng)建一個簡單的數(shù)組
local arr1 = {1,2,3,4,5,6}
--遍歷數(shù)組中得每一個元素
for i,v in ipairs(arr1) do
print(v)
end

--另一種創(chuàng)建數(shù)組的方式
local arr2 = {}
for i=1,10 do
arr2[i] = i
print(arr2[i])
end

--創(chuàng)建數(shù)組,下標(biāo)從2開始
local arr2 = {[2]="hello",[3]="xiao",[4]="ta",[5]="zaojiahua"}
--使用迭代器ipairs遍歷的時候輸出為空值,因為arr2[1]=nil當(dāng)ipairs遇到空值的時候就返回了
for i,v in ipairs(arr2) do
print(i,v)
end
--這個時候需要使用pairs遍歷
for i,v in pairs(arr2) do
print(i,v)
end

創(chuàng)建數(shù)組的時候整數(shù)下標(biāo)最好從1開始,因為這個值是Lua中默認(rèn)開始的下標(biāo),這和其他語言的下標(biāo)從零開始有點區(qū)別,如果你采用其他的數(shù)字下標(biāo)開始,使用某些Lua庫的時候可能不能獲得預(yù)期的結(jié)果。然后就是遍歷數(shù)組的方式,我們用到了迭代器ipairs()和pairs(),這個使用時候的區(qū)別代碼已經(jīng)有體現(xiàn)了,ipairs中得i代表的就是整數(shù)下標(biāo),從1開始。

有一維數(shù)組當(dāng)然就有多維的,下面來創(chuàng)建一個二維數(shù)組,也就是矩陣,其他的類推吧。

復(fù)制代碼 代碼如下:

--創(chuàng)建一個10*5的二維數(shù)組
local int_arr = {}

for i=1,10 do
    int_arr[i] = {}
    for j=1,5 do
        int_arr[i][j] = j
    end
end

--遍歷二維數(shù)組
for i,v in ipairs(int_arr) do
    for j,k in ipairs(v) do
        io.write(k.."\t")
    end
    print("\n")
end


接下來實現(xiàn)一個鏈表,鏈表的每個節(jié)點用一個table表示,table中的字段包括指向下一個節(jié)點的指針和該節(jié)點的數(shù)據(jù)元素,這里只是提供一個思路,其他的東西可以用的時候擴展。

復(fù)制代碼 代碼如下:

--實現(xiàn)一個鏈表
local list = nil
--鏈表元素包含倆個字段,next代表的是指針,指向下一個鏈表元素,value代表的是該鏈表元素的值
for i=1,10 do
    list = {next = list,value = i}
end

--鏈表的遍歷
local l = list
while l do
    print(l.value)
    l = l.next
end


接下來實現(xiàn)一個比較有用的數(shù)據(jù)結(jié)構(gòu)——隊列。我把隊列封裝在了一個table表中,關(guān)于隊列的操作和表示隊列頭和隊列尾的指針也封裝在了一起。當(dāng)對頭等于隊尾的時候表示沒有元素,而這個隊列是可以無限增大的,并沒有隊列滿的限制,大家可以根據(jù)自己的需要進行擴展。

復(fù)制代碼 代碼如下:

--實現(xiàn)一個隊列 包括頭指針first和尾指針last first==last的時候代表隊列為空
local Que = {first=0,last=0}

--向隊列中添加元素,last索引指向最后一個元素的下一個元素,first索引指向的是第一個元素
function Que:push(value)
    local last = self.last
    self[last] = value
    self.last = last+1
end
--移除元素,隊列的特點是先進先出
function Que:pop()
    if self.first == self.last then
        print("隊列空")
        return nil
    end
    local first = self.first
    self.first = first+1
    return self[first]
end

--顯示隊列中得元素
function Que:showValue()
    for i=self.first,self.last-1 do
        print("value:"..self[i])
    end
end

--測試
print("隊列測試")
Que:showValue()
Que:push(2)
Que:push(3)
print("push 2,3")
Que:showValue()
Que:push(3)
print("push 3")
Que:showValue()
print("pop:"..Que:pop())
Que:showValue()
print("pop:"..Que:pop())
Que:showValue()
print("push 100")
Que:push(100)
Que:showValue()
print("pop:"..Que:pop())
Que:showValue()
print("pop:"..Que:pop())
Que:showValue()
print("pop:"..Que:pop())

相關(guān)文章

  • Lua中的模塊(module)和包(package)詳解

    Lua中的模塊(module)和包(package)詳解

    這篇文章主要介紹了Lua中的模塊(module)和包(package)詳解,本文講解了require函數(shù)、寫一個模塊、package.loaded、module函數(shù)等內(nèi)容,需要的朋友可以參考下
    2014-09-09
  • Lua中的loadfile、dofile、loadstring、require用法實例

    Lua中的loadfile、dofile、loadstring、require用法實例

    這篇文章主要介紹了Lua中的loadfile、dofile、loadstring、require用法實例,需要的朋友可以參考下
    2015-04-04
  • Lua中的邏輯運算符使用詳解

    Lua中的邏輯運算符使用詳解

    這篇文章主要介紹了Lua中的邏輯運算符使用詳解,是Lua入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • lua調(diào)用C/C++的方法詳解

    lua調(diào)用C/C++的方法詳解

    lua是腳本語言,優(yōu)點是門檻低,可以熱更新,缺點當(dāng)然就是性能,C/C++是編譯型語言,有點是性能高,但是相對的,門檻高,lua語言本身就是用C實現(xiàn)的,而且,可以將很多能力封裝成lua的接口供lua調(diào)用,本文將給大家介紹lua如何調(diào)用C/C++,需要的朋友可以參考下
    2023-10-10
  • Lua中使用.和:調(diào)用函數(shù)的區(qū)別

    Lua中使用.和:調(diào)用函數(shù)的區(qū)別

    這篇文章主要介紹了Lua中使用.和:調(diào)用函數(shù)的區(qū)別,本文總結(jié)了它的調(diào)用函數(shù)的時傳入?yún)?shù)的區(qū)別,并給出了一個代碼實例,需要的朋友可以參考下
    2015-04-04
  • Lua教程(六):編譯執(zhí)行與錯誤

    Lua教程(六):編譯執(zhí)行與錯誤

    這篇文章主要介紹了Lua教程(六):編譯執(zhí)行與錯誤,本文講解了、C代碼、錯誤、錯誤處理與異常、錯誤消息與追溯等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • Lua中的源代碼預(yù)編譯淺析

    Lua中的源代碼預(yù)編譯淺析

    這篇文章主要介紹了Lua中的源代碼預(yù)編譯淺析,Lua確實允許在運行源代碼之前,將源代碼預(yù)編譯成一種中間形式(類比Python的.pyc),需要的朋友可以參考下
    2014-09-09
  • 詳解Lua中repeat...until循環(huán)語句的使用方法

    詳解Lua中repeat...until循環(huán)語句的使用方法

    這篇文章主要介紹了詳解Lua中repeat...until循環(huán)語句的使用方法,需要的朋友可以參考下
    2015-05-05
  • Lua中的弱引用介紹

    Lua中的弱引用介紹

    這篇文章主要介紹了Lua中的弱引用介紹,本文用一個實例講解了Lua弱引用的相關(guān)知識,需要的朋友可以參考下
    2015-04-04
  • Lua中的協(xié)同程序詳解

    Lua中的協(xié)同程序詳解

    這篇文章主要介紹了Lua中的協(xié)同程序詳解,本文非常詳細(xì)的講解了Lua中的協(xié)同程序,同時講解了生產(chǎn)者-消費者問題,需要的朋友可以參考下
    2014-09-09

最新評論