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 函数来打印输出变量的值或者文本信息。

主程序

lua 复制代码
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函数用于输出结果

相关推荐
钟智强7 天前
CVE-2025-49844高危预警:Redis Lua脚本引擎UAF漏洞深度剖析与POC实战
数据库·redis·web安全·junit·lua
闲人编程7 天前
聚合管道与复杂查询
开发语言·oracle·lua·match·查询·聚合·lookup
会周易的程序员8 天前
cNetgate物联网网关内存数据表和数据视图模块架构
c语言·c++·物联网·架构·lua·iot
会周易的程序员9 天前
cNetgate插件架构设计详解 动态库 脚本二开lua, python, javascript
javascript·c++·python·物联网·lua·iot
白太岁13 天前
Redis:(3) Lua 与 Redis、基于连接池的 Facade 模式封装
数据库·c++·redis·lua·外观模式
Maguyusi18 天前
go 批量生成c++和lua proto文件
c++·golang·lua·protobuf
foxsen_xia18 天前
Kamailio通过Lua写路由
开发语言·lua·信息与通信
码农周20 天前
nginx + Lua 实现域名访问日志统计
nginx·lua
難釋懷22 天前
Lua脚本解决多条命令原子性问题
开发语言·lua
AI_567825 天前
Postman接口测试提速技巧:批量请求+智能断言实践
测试工具·lua·postman