-- lua链表的实现

 node = {}
list = node --初始化,构建一个空表
function init()
list.data = --我将头结点的数据域存放链表的长度,以免浪费空间
list.next = nil
end --向链表的尾部添加数据
function addRear(d)
node.next={}--建立一个节点,相当于malloc一个节点
node = node.next
node.next = nil
node.data = d
list.data = list.data + -- 长度加1
end --向链表的头部添加数据
function addHead(d)
newNode = {}--建立一个节点,相当于malloc一个节点
newNode.data = d
newNode.next = list.next
list.next = newNode
list.data = list.data +
end --第i个位置 插入数据d i>=1
function insert(i,d)
if i< then
print('插入位置不合法')
return
end local j, k, l = i-, , list
-- 解决问题的核心是找到第j个位置
while k<j do
k=k+
l = l.next
if not l.next then break end
end
if k ~= j then
print('插入位置不合法')
return
end --开始插入
newNode = {}
newNode.next = l.next
newNode.data = d
l.next = newNode
list.data = list.data +
end --删除第i个位置的数据 i>=1,返回删除的数据的内容
function del(i)
if i< then
print('删除位置不合法')
return
end
local j, k ,l= i-, ,list
while k<j do
k=k+
l = l.next
if not l.next then
print('删除位置不合法')
return
end
end d = l.next.data
t = l.next.next -- 保存删除节点之后的链表内容
l.next = nil --lua中让它等于nil就删除了
l.next = t
list.data = list.data - -- 链表长度减1
return d
end --清除链表,操作完成后,链表还在,只不过为空
function clear()
if not list then -- 先判断链表是否还存在
print('链表不存在')
end while true do
firstNode = list.next
if not firstNode then -- 表示链表成为空表了
break
end
t = firstNode.next -- 保存第一个节点之后的链表
list.next = nil -- 删除
list.next = t
end
list.data = -- 将长度置0
print('-- clear ok --')
end -- 销毁链表
function destroy()
clear() -- 先清除链表
list = nil
end --获取list中的第i个元素 i>=1
function getData(i)
if not list then
print('链表不存在')
return
end
if i< then
print('位置不合法')
return
end local l = list.next -- l 指向第一个元素
local k =
while l do
l = l.next
k = k+
if k == i then
return l.data
end
end print('位置不合法')
end --获取链表的长度
function getLen()
if not list then
print('链表不存在')
return
end
return list.data
end --打印链表的每一个元素
function display()
local l=list.next
while l do
print(l.data)
l = l.next
end
print('-- display ok --')
end --主方法
function main()
init() -- 初始化链表
addRear()
addRear()
addRear()
addHead() --向头部添加
addRear() --向尾部添加
insert(,) --在第1个位置插入3
insert(,) -- 在第三个位置插入100
display() -- 打印链表的每一个元素
print('请输入要删除的位置:')
pos = io.read('*number')
ret = del(pos)
if not ret then
print('删除失败')
else
print('你删除的是:',ret,'\n删除后的链表内容为:')
end
-- 打印改变后内容
display()
--clear()
--display() i =
print('第'..i..'个元素内容是:',getData(i))
print('链表的的长度为:',getLen()) destroy() -- 销毁链表
print ('---- main ok ----')
end -- 程序的入口
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两天,如有错误之处,请谅解。

lua之链表的实现的更多相关文章

  1. lua单链表实现

    List = {} --创建一个节点 function List.new(val) return {pnext = nil, value = val} end --往一个节点后添加一个节点 funct ...

  2. [lua]紫猫lua教程-命令宝典-L1-01-12. 临时补充2

    1.lua的环境变量和函数 (1)_G表  (个人习惯遍历下_G 看看当前环境支持什么库 很多库不是默认就支持的 需要按照流程导入或者加载) 一个全局变量(非函数),内部储存有当前所有的全局函数和全局 ...

  3. chapter11_2 Lua链表与队列

    链表 由于table是动态的实体,所以在Lua中实现链表是很方便的.每个节点以一个table来表示,一个“链表”只是节点table中的一个字段. 该字段包含了对其他table的引用.例如,要实现一个基 ...

  4. lua解析赋值类型代码的过程

    我们来看看lua vm在解析下面源码并生成bytecode时的整个过程: foo = "bar" local a, b = "a", "b" ...

  5. 15分钟学会Lua

    lua的很多语法跟matlab很像 最基本的赋值是一样的 循环和选择判断后面必须跟一个关键字:do和then ,, do ... end if - then - end table是lua的唯一一种数 ...

  6. lua解析脚本过程中的关键数据结构介绍

    在这一篇文章中我先来介绍一下lua解析一个脚本文件时要用到的一些关键的数据结构,为将来的一系列代码分析打下一个良好的基础.在整个过程中,比较重要的几个源码文件分别是:llex.h,lparse.h.l ...

  7. lua中的string类型

    在lua中用union TString来表示字符串类型 lobject.h: 其中结构体tsv中 reserved字段表示字符串是不是保留关键字,hash是其哈希值,len是其长度.我们在TStrin ...

  8. Lua 学习笔记(十)数据结构

    在Lua中的table不是一种简单的数据结构,它可以作为其他数据结构的基础.其他语言提供的数据结构,如数组.记录.线性表.队列.集合等,在Lua中都可以通过table来表示.而且使用Lua实现这些数据 ...

  9. lua 类支持属性不能被修改

    背景 lua是类是借助表的来实现的, 类被定义后, 在使用场景下, 不希望被修改.如果被修改, 则影响的类的原始定义, 影响所有使用类的地方. 例如: --- router.lua class fil ...

随机推荐

  1. 【转】zip() 函数

    描述 zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符 ...

  2. VS2010打包回顾

    1.  在vs2010 选择“新建项目”à“ 其他项目类型”à“ Visual Studio Installerà “安装项目”: 命名为:Setup1 . 这是在VS2010中将有三个文件夹, 1. ...

  3. Ubuntu adb devices :???????????? no permissions 解决方法[转]

    转自: http://www.cnblogs.com/cat-lee/archive/2011/07/09/2101718.html untun下USB连接Android手机后,使用adb devic ...

  4. HDU6012:Lotus and Horticulture(扫描线)(前缀和)

    传送门 题意 给出n种植物的适宜培育温度区间[l,r],低于下限获值c,高于上限获值b,其他获值a 分析 首先考虑应该尝试选择哪些点:区间的左右端点.与区间左右端点距离0.50.5的点,这样就一定可以 ...

  5. Linux 常用命令十六 文件权限管理

    一.ls -l 各段含义 wang@wang:~/workpalce/threading$ ls -l 总用量 drwxrwxr-x wang wang 12月 : a -rw-rw-r-- wang ...

  6. css覆盖select样式并添加小箭头

    .select { border-radius: 5px; border: 1px #F4A627 solid; -webkit-appearance: none;//清除默认样式 backgroun ...

  7. Latex排版工具的使用(一) 分类: Latex 2014-06-14 22:52 448人阅读 评论(0) 收藏

    使用Latex可以排版出漂亮的论文,尤其适合对含有数学公式论文的排版. 下面编写第一Latex源文件,实现对两个数学公式的排版: 新建文件first.tex: \documentclass{artic ...

  8. CoreText的绘制流程-转

    来自:http://blog.sina.com.cn/s/blog_7c8dc2d50101lbb1.html 使用coreText进行文本绘制,需要在工程中添加CoreText.framework, ...

  9. 支付宝添加scheme的方法

    点击项目名称,点击“Info”选项卡,在“URL Types”选项中,点击“+”,在“URL Schemes”中输入“myAlipay”.“myAlipay”来自于文件“APViewControlle ...

  10. vijos P1629八 容斥原理

    https://vijos.org/p/1629 注意lcm要用LL 先给一个样例 1 2 1 10 思路.其实这题就是问,给定一堆数,要求不能整除其任意一个的数字有多少个. 容辞 + lcm dfs ...