001 线性查找(lua)

文章目录

迭代器

-- 定义一个名为 linearSearch 的函数,它接受两个参数:data(一个数组)和 target(一个目标值)  
function linearSearch(data, target)  
    -- 使用 for 循环遍历数组 data,ipairs 是一个迭代器,用于在数组中遍历键值对  
    for i, v in ipairs(data) do  
        -- 如果当前遍历到的值 v 等于目标值 target  
        if v == target then  
            -- 找到目标值,返回其索引 i  
            return i  
        end  
    end  
    -- 如果循环结束都没有找到目标值,返回 -1  
    return -1  
end  
  
-- 定义一个数组 data,包含一系列整数  
data = {13, 66, 54, 73, 23, 55, 18}  
-- 定义一个变量 target,赋值为 66  
target = 66  
  
-- 调用 linearSearch 函数,并将结果赋值给变量 res  
res = linearSearch(data, target)  
-- 打印变量 res 的值  
print(res)

Lua 脚本语法的关键点:

函数定义:
function 关键字用于定义函数。
函数名后面跟着括号,括号内是函数的参数列表。
函数体跟在参数列表之后,用 end 关键字结束。
for 循环:
Lua 中的 for 循环可以配合迭代器使用,例如 ipairs 用于遍历数组的索引和值。
for i, v in ipairs(data) do 表示对数组 data 进行遍历,i 是索引,v 是对应的值。
条件语句:
if 语句用于进行条件判断。
如果条件为真(true),则执行 then 后面的代码块。
可以使用 else 和 elseif 来处理其他情况。
return 语句:
用于从函数中返回值。
如果函数中没有 return 语句,或者 return 后面没有跟任何值,则默认返回 nil。
数组和变量:
Lua 中的数组使用花括号 {} 定义,数组元素之间用逗号分隔。
变量不需要提前声明,直接使用赋值语句即可创建和初始化。
打印输出:
使用 print 函数来打印输出变量的值或者文本信息。

主程序


function linearSearch(data, target)  
    for i = 1, #data do  -- 这是一个for循环,用于遍历数组data。#data获取数组data的长度。Lua中的数组索引从1开始,所以循环变量i从1开始,到数组的长度结束。
        if data[i] == target then  
            return i 
        end  
    end  
    return -1  
end  
  
-- Main program  
do  
    local data = {13, 66, 54, 73, 23, 55, 18}  
    local target = 66  
  
    local res = linearSearch(data, target)  
    print(res)  
end

Lua 数组的索引是从1开始的,也就是说它们的索引从1开始计数。
Lua我们定义了一个全局函数linearSearch来执行搜索。
在Lua中,我们使用一个匿名的do … end块来包含主程序逻辑。这个块在脚本运行时会被立即执行。
在Lua中,局部变量是使用local关键字声明的。这有助于避免污染全局命名空间。
Lua中的print函数用于输出结果

  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

简 洁 冬冬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值