• 数组


    数组是对象的有序排列,可以是包含行集合的一维数组或包含多个行和列的多维数组。

    在Lua中,使用带整数的索引表实现数组。 数组的大小不固定,它可以根据要求增长,受内存限制。

    一维数组一维数组可以使用简单的表结构表示,并且可以使用for循环进行初始化和读取。 如下例子所示。

    array = {"Lua", "Tutorial"}

    for i = 0, 2 do

       print(array[i])

    end

    当运行上面的代码时,将得到以下输出结果 -

    nil

    Lua

    Tutorial

    正如在上面的代码中所看到的,当尝试访问数组中不存在的索引中的元素时,它返回nil值。 在Lua中,索引通常从索引1开始。但是也可以在索引0和0以下(负数)创建对象。 使用负索引的数组如下所示,使用for循环初始化数组。

    array = {}

    for i= -2, 2 do

       array[i] = i *2

    end

    for i = -2,2 do

       print(array[i])

    end

    当运行上面的代码时,将得到以下输出结果 -

    -4

    -2

    0

    2

    4

    Shell

    多维数组多维数组有两种方式实现。它们分别如下 -

    数组的数组通过操纵一维数组的索引

    下面是使用数组阵列 3 x 3的多维数组的示例。

    -- 初始化数组

    array = {}

    for i=1,3 do

       array[i] = {}

       for j=1,3 do

          array[i][j] = i*j

       end

    end

    -- 访问数组

    for i=1,3 do

       for j=1,3 do

          print(array[i][j])

       end

    end

    Lua

    当运行上面的代码时,将得到以下输出结果 -

    1

    2

    3

    2

    4

    6

    3

    6

    9

    下面使用操作索引显示多维数组的示例。

    -- 初始化数组

    array = {}

    maxRows = 3

    maxColumns = 3

    for row=1,maxRows do

       for col=1,maxColumns do

          array[row*maxColumns +col] = row*col

       end

    end

    -- 访问数组

    for row=1,maxRows do

       for col=1,maxColumns do

          print(array[row*maxColumns +col])

       end

    end

    当运行上面的代码时,将得到以下输出结果 -

    1

    2

    3

    2

    4

    6

    3

    6

    9

    如在上面的示例中所看到的,数据是基于索引存储的。 可以以稀疏的方式放置元素,这是Lua实现数组的方式。 在Lua中由于它没有存储nil值,因此与其他编程语言中使用的特殊技术相比,Lua中可以节省大量内存而无需任何特殊技术。

     array={}

    for i=1,9 do

          array[i] = {}

       for j=i,9 do

          array[i][j] = i*j

       end

    end

    -- 访问数组

    for i=1,9 do

       for j=i,9 do

         -- print(i.."x"..j.."="array[i][j])

            str = string.format("%dX%d=%d",j,i,array[i][j]) 

            print(str) 

       end

          --print(" ")

    end

  • 相关阅读:
    LF.51.Insert In Binary Search Tree
    Use Array To Implement Queue With Size(bounded)
    Use LinkedList to implement Queue
    Use LinkedList to Implement Stack
    LT.11.Search Range In Binary Search Tree
    Odoo 12开发之后台视图 – 设计用户界面 ###
    Odoo 之业务逻辑
    Odoo开发之记录集 – 使用模型数据
    odoo 之 结构化应用数据
    odoo之数据导入导出以及模块数据
  • 原文地址:https://www.cnblogs.com/gd-luojialin/p/10962745.html
Copyright © 2020-2023  润新知