lua之链表的实现 luna是什么链

   2023-02-09 学习力0
核心提示:1 -- lua链表的实现2 3 node = {}4 list = node5 6 --初始化,构建一个空表7 function init()8 list.data = 0 --我将头结点的数据域存放链表的长度,以免浪费空间9 list.next = nil 10 end 1112 --向链表的尾部添加数据 13 function addRear(d) 14 node.next=
  1 -- lua链表的实现
  2 
  3 node = {}
  4 list = node
  5 
  6 --初始化,构建一个空表
  7 function init()
  8     list.data = 0 --我将头结点的数据域存放链表的长度,以免浪费空间
  9     list.next = nil
 10 end
 11 
 12 --向链表的尾部添加数据
 13 function addRear(d)
 14     node.next={}--建立一个节点,相当于malloc一个节点
 15     node = node.next
 16     node.next = nil
 17     node.data = d
 18     list.data = list.data + 1 -- 长度加1
 19 end
 20 
 21 --向链表的头部添加数据
 22 function addHead(d)
 23     newNode = {}--建立一个节点,相当于malloc一个节点
 24     newNode.data = d
 25     newNode.next = list.next
 26     list.next = newNode
 27     list.data = list.data + 1
 28 end
 29 
 30 
 31 --第i个位置 插入数据d   i>=1
 32 function insert(i,d)
 33     if i<1 then
 34         print('插入位置不合法')
 35         return
 36     end
 37 
 38     local j, k, l = i-1, 0, list
 39     -- 解决问题的核心是找到第j个位置
 40     while k<j do
 41         k=k+1
 42         l = l.next
 43         if not l.next then break end
 44     end
 45     if k ~= j then
 46         print('插入位置不合法')
 47         return
 48     end
 49 
 50     --开始插入
 51     newNode = {}
 52     newNode.next = l.next
 53     newNode.data = d
 54     l.next = newNode
 55     list.data = list.data + 1
 56 end
 57 
 58 
 59 --删除第i个位置的数据  i>=1,返回删除的数据的内容
 60 function del(i)
 61     if i<1 then
 62         print('删除位置不合法')
 63         return
 64     end
 65     local j, k ,l= i-1, 0,list
 66     while k<j do
 67         k=k+1
 68         l = l.next
 69         if not l.next then
 70             print('删除位置不合法')
 71             return
 72         end
 73     end
 74 
 75     d = l.next.data
 76     t = l.next.next -- 保存删除节点之后的链表内容
 77     l.next = nil --lua中让它等于nil就删除了
 78     l.next = t
 79     list.data = list.data - 1 -- 链表长度减1
 80     return d
 81 end
 82 
 83 
 84 --清除链表,操作完成后,链表还在,只不过为空
 85 function clear()
 86     if not list then -- 先判断链表是否还存在
 87         print('链表不存在')
 88     end
 89 
 90     while true do
 91         firstNode = list.next
 92         if not firstNode then -- 表示链表成为空表了
 93             break
 94         end
 95         t = firstNode.next -- 保存第一个节点之后的链表
 96         list.next = nil -- 删除
 97         list.next = t
 98     end
 99     list.data = 0 -- 将长度置0
100     print('-- clear ok --')
101 end
102 
103 -- 销毁链表
104 function destroy()
105     clear() -- 先清除链表
106     list = nil
107 end
108 
109 --获取list中的第i个元素 i>=1
110 function getData(i)
111     if not list then
112         print('链表不存在')
113         return
114     end
115     if i<1 then
116         print('位置不合法')
117         return
118     end
119 
120     local l = list.next -- l 指向第一个元素
121     local k = 1
122     while l do
123         l = l.next
124         k = k+1
125         if k == i then
126             return l.data
127         end
128     end
129 
130     print('位置不合法')
131 end
132 
133 --获取链表的长度
134 function getLen()
135     if not list then
136         print('链表不存在')
137         return
138     end
139     return list.data
140 end
141 
142 --打印链表的每一个元素
143 function display()
144     local l=list.next
145     while l do
146         print(l.data)
147         l = l.next
148     end
149     print('-- display ok --')
150 end
151 
152 --主方法
153 function main()
154     init() -- 初始化链表
155     addRear(5)
156     addRear(7)
157     addRear(10)
158     addHead(1) --向头部添加
159     addRear(20) --向尾部添加
160     insert(1,3) --在第1个位置插入3
161     insert(3,100) -- 在第三个位置插入100
162     display() -- 打印链表的每一个元素
163     print('请输入要删除的位置:')
164     pos = io.read('*number')
165     ret = del(pos)
166     if not ret then
167         print('删除失败')
168     else
169         print('你删除的是:',ret,'\n删除后的链表内容为:')
170     end
171     -- 打印改变后内容
172     display()
173     --clear()
174     --display()
175 
176     i = 3
177     print(''..i..'个元素内容是:',getData(i))
178     print('链表的的长度为:',getLen())
179 
180     destroy() -- 销毁链表
181     print ('---- main ok ----')
182 end
183 
184 -- 程序的入口
185 main()

程序运行结果:

3
1
100
5
7
10
20
-- display ok --
请输入要删除的位置:
3
你删除的是: 100
删除后的链表内容为:
3
1
5
7
10
20
-- display ok --
第3个元素内容是: 5
链表的的长度为: 6
---- main ok ----

 

本人不是什么大牛,才学lua两天,如有错误之处,请谅解。

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • LUA解析json小demo
    需要修改的json数据gui-config.json{"configs": [{"server": "JP3.ISS.TF","server_port": 443,"password": "58603228","method": "aes-256-cfb","remarks": ""},{"serv
    03-16
  • 第二十三篇:在SOUI中使用LUA脚本开发界面
    像写网页一样做客户端界面可能是很多客户端开发的理想。做好一个可以实现和用户交互的动态网页应该包含两个部分:使用html做网页的布局,使用脚本如vbscript,javascript做用户交互的逻辑。当需求变化时,只需要在服务端把相关代码调整一下,用户即可看到新的
    03-16
  • windows下编译lua源码"><转>windows下编译lua源
    因为之前一直使用 lua for windows 来搭建lua的使用环境,但是最新的 lua for windows 还没有lua5.2,我又想用这个版本的lua,所以被逼无奈只能自己编一下lua源码。首先从 lua的官网 下载你想要使用的lua源码,比如我下载的就是lua5.2。解压后内容如下:
    03-16
  • lua:使用Lua处理游戏数据
    在之前lua学习:lua作配置文件里,我们学会了用lua作配置文件。其实lua在游戏开发中可以作为一个强大的保存、载入游戏数据的工具。 比如说,现在我有一份表单:data.xls用什么工具解析这个Excel文件并将数据载入游戏?我们可以使用Lua来完成这个工作。不过要
    03-16
  • 第1课 - 学习 Lua 的意义
    第1课 - 学习 Lua 的意义
    第1课 - 学习 Lua 的意义1.Lua 简介           (1) 1993年、巴西(2) 小巧精致的脚本语言,大小只有 200K(3) 用标准C语言写成,能够在所有的平台上编译运行(4) 发明的目标是嵌入在C/C++中,为应用程序提供灵活的扩展和定制功能(5) 不适合用于开发
    03-16
  • RedisTemplate 常用API+事务+陷阱+序列化+pipeline+LUA
    RedisTemplate 常用API+事务+陷阱+序列化+pipel
    https://www.jianshu.com/p/7bf5dc61ca06/https://blog.csdn.net/qq_34021712/article/details/79606551https://www.jianshu.com/p/c9f5718e58f0dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId/depe
    03-08
  • Nginx动态路由的新姿势:使用Go取代lua nginx路由规则
    Nginx动态路由的新姿势:使用Go取代lua nginx路
    导语: 在Nitro 中, 我们需要一款专业的负载均衡器。 经过一番研究之后,Mihai Todor和我使用Go构建了基于Nginx、Redis 协议的路由器解决方案,其中nginx负责所有繁重工作,路由器本身并不承载流量。 这个解决方案过去一年在生产环境中运行顺畅。 以下是我
    03-08
  • cocos2d-lua 控制台输入Lua指令方便调试
    用脚本进行开发,如果不能实时去输入指令,就丧失了脚本的一大特色,所以对cocos2d-x程序稍微修改下,使其可以直接从控制台读入lua指令,方便调试。1 首先在行首加入lua的引用,如下1 #include "main.h"2 #include "AppDelegate.h"3 #include "cocos2d.h"4 #i
    02-09
  • lua_touserdata
    void *lua_touserdata(lua_State*L,intindex);如果给定索引处的值是一个完整的userdata,函数返回内存块的地址。如果值是一个lightuserdata,那么就返回它表示的指针。否则,返回NULL。例如: 在CCLuaStack::executeFunction()函数中有一段代码是用来获取c++
    02-09
  • Lua 5.2 中文参考手册
    闲来无事,发现Lua更新到了5.2.2,参考手册也更到了5.2,在网上发现只有云风翻译的5.1版,花了几天时间翻译了一些。参考手册有点长,又要随时修改,所以在github上建了项目,有需要的朋友可以看看,同时也欢迎指正。中文手册:Lua 5.2中文参考手册
    02-09
点击排行