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函数用于输出结果

相关推荐
VT LI1 天前
Lua 源码执行流程全解析:词法分析、语法分析、字节码生成、虚拟机执行与垃圾回收
java·开发语言·lua
历程里程碑2 天前
二叉树---二叉树的中序遍历
java·大数据·开发语言·elasticsearch·链表·搜索引擎·lua
上海合宙LuatOS3 天前
LuatOS扩展库API——【exremotefile】远程文件管理系统
物联网·lua·luatos
上海合宙LuatOS3 天前
LuatOS扩展库API——【exremotecam】网络摄像头控制
开发语言·网络·物联网·lua·luatos
专吃海绵宝宝菠萝屋的派大星4 天前
使用postman测试自己编写的mcp服务
测试工具·lua·postman
一个有温度的技术博主4 天前
Lua语法详解:从变量声明到循环遍历的避坑指南
redis·缓存·lua
上海合宙LuatOS4 天前
LuatOS扩展库API——【exmodbus】MODBUS协议
物联网·lua·luatos
一个有温度的技术博主4 天前
Lua语法进阶:函数封装与条件控制的艺术
redis·分布式·缓存·lua
小李云雾5 天前
FastAPI 后端开发:文件上传 + 表单提交
开发语言·python·lua·postman·fastapi
曼巴UE55 天前
Unlua 官方案例
c++·ue5·lua·ue