数据结构 --- 线性表学习(php模拟)
线性表:零个或多个数据元素的有限序列(注:以下都是用的整型数据模拟)
一 顺序存储结构(用一段地址连续的存储单元一次存储线性表的数据元素)
1.1 三个属性:存储空间的起始位置;最大存储容量;当前长度
注:数组长度是存放线性表的存储空间的长度(一般是不变的),不过语言可以动态增加容量,会带来性能损耗;
线性表长度是数据元素的个数;
线性表是从1开始数的,对应数组0的位置
1.2 获取元素、插入元素、删除元素(代码中展示)
1.3 顺序结构优缺点:
优点:无须为表示表中元素之间的逻辑关系而增加额外的存储空间;可以快速地存取表中任一位置元素
缺点:插入和删除操作需要移动大量的元素;当线性表长度裱花较大时,难以确定存储空间容量;造成存储空间'碎片'
<span style="color: #008000;"> //</span><span style="color: #008000;">用一维数组模拟线性表</span> <span style="color: #0000ff;">class</span><span style="color: #000000;"> Sequential_Structure { </span><span style="color: #008000;">//</span><span style="color: #008000;">线性表的长度</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$num</span> = 0<span style="color: #000000;">; </span><span style="color: #008000;">//</span><span style="color: #008000;">数组长度</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$len</span> = 0<span style="color: #000000;">; </span><span style="color: #008000;">//</span><span style="color: #008000;">数组模拟</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$arr</span> = <span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 初始化结构 * @param Int $len 最大数组长度 * @param Array $arr 数组 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> __construct(<span style="color: #800080;">$len</span>, <span style="color: #0000ff;">Array</span> <span style="color: #800080;">$arr</span><span style="color: #000000;">) { </span><span style="color: #800080;">$this</span>->len = <span style="color: #800080;">$len</span><span style="color: #000000;">; </span><span style="color: #800080;">$length</span> = <span style="color: #008080;">count</span>(<span style="color: #800080;">$arr</span><span style="color: #000000;">); </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$length</span> > 0 && <span style="color: #800080;">$length</span> $len<span style="color: #000000;">) { </span><span style="color: #800080;">$this</span>->arr = <span style="color: #800080;">$arr</span><span style="color: #000000;">; </span><span style="color: #800080;">$this</span>->num = <span style="color: #800080;">$length</span><span style="color: #000000;">; } } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取线性表元素 * @param Int $i 需要获取的第几个元素 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> get_elem(<span style="color: #800080;">$i</span><span style="color: #000000;">) { </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$this</span>->num == 0 || <span style="color: #800080;">$i</span> $i > <span style="color: #800080;">$this</span>->num) <span style="color: #008000;">//</span><span style="color: #008000;">判断查找是否合理</span> <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">return</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>-1]; <span style="color: #008000;">//</span><span style="color: #008000;">返回数据,时间复杂度O(1)</span><span style="color: #000000;"> } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 插入元素(顺序结构中,插入元素后,后面所有的数据都要后移,平均时间复杂度O(1)): * 如果插入位置不合理,失败 * 如果线性长度大于数组长度,则返回错误或者动态增加容量 * 从最后一个元素开始向前遍历到第i个位置,分别将它们向后移动一个位置 * 将元素插入i位置 * @param Int $i 需要插入到第几个元素 * @param Int $elem 插入的节点 * @return bool </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> insert_elem(<span style="color: #800080;">$i</span>, <span style="color: #800080;">$elem</span><span style="color: #000000;">) { </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$this</span>->num == <span style="color: #800080;">$this</span>->len) <span style="color: #008000;">//</span><span style="color: #008000;">顺序线性表已满</span> <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $i > (<span style="color: #800080;">$this</span>->num+1)) <span style="color: #008000;">//</span><span style="color: #008000;">i不在范围之内</span> <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$i</span> $this->num) <span style="color: #008000;">//</span><span style="color: #008000;">若数据插入位置不在表尾</span><span style="color: #000000;"> { </span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$k</span> = <span style="color: #800080;">$this</span>->num-1; <span style="color: #800080;">$k</span> >= <span style="color: #800080;">$i</span>-1; --<span style="color: #800080;">$k</span>) <span style="color: #008000;">//</span><span style="color: #008000;">后面所有元素往后移动一位</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$k</span>+1] = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$k</span><span style="color: #000000;">]; } </span><span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>-1] = <span style="color: #800080;">$elem</span>; <span style="color: #008000;">//</span><span style="color: #008000;">插入元素</span> ++<span style="color: #800080;">$this</span>-><span style="color: #000000;">num; </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 删除元素(顺序结构中,插入元素后,后面所有的数据都要前移,平均时间复杂度O(1)): * 如果删除位置不合理,失败 * 将元素删除 * 从最后删除元素开始向后遍历到最后,分别将它们向前移动一个位置 * @param Int $i 需要仓储的第几个元素 * @return bool </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> delete_elem(<span style="color: #800080;">$i</span><span style="color: #000000;">) { </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$this</span>->num == 0) <span style="color: #008000;">//</span><span style="color: #008000;">线性表为空</span> <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $i > <span style="color: #800080;">$this</span>->num) <span style="color: #008000;">//</span><span style="color: #008000;">删除位置不正确</span> <span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $this->num) <span style="color: #008000;">//</span><span style="color: #008000;">删除位置不是表尾</span><span style="color: #000000;"> { </span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$k</span> = <span style="color: #800080;">$i</span>; <span style="color: #800080;">$k</span> $this->num; ++<span style="color: #800080;">$k</span>) <span style="color: #008000;">//</span><span style="color: #008000;">前移</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$k</span>-1] = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$k</span><span style="color: #000000;">]; } </span><span style="color: #0000ff;">unset</span>(<span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$this</span>->num-1<span style="color: #000000;">]); </span>--<span style="color: #800080;">$this</span>-><span style="color: #000000;">num; </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取顺序表 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> get_arr() { </span><span style="color: #0000ff;">return</span> <span style="color: #800080;">$this</span>-><span style="color: #000000;">arr; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取长度 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> get_len() { </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">array</span>('num' => <span style="color: #800080;">$this</span>->num , 'len' => <span style="color: #800080;">$this</span>-><span style="color: #000000;">len); } } </span><span style="color: #800080;">$link</span> = <span style="color: #0000ff;">new</span> Sequential_Structure(10,[1,4,8,7<span style="color: #000000;">]); </span><span style="color: #0000ff;">echo</span> <span style="color: #800080;">$link</span>->get_elem(2<span style="color: #000000;">); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->insert_elem(5,5<span style="color: #000000;">)); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>-><span style="color: #000000;">get_arr()); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>-><span style="color: #000000;">get_len()); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->delete_elem(1<span style="color: #000000;">)); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>-><span style="color: #000000;">get_arr()); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->get_len());
<span style="color: #0000ff;">输出:<br>boolean</span> <span style="color: #0000ff;">true</span><span style="color: #0000ff;">array</span> (size=5<span style="color: #000000;">) </span>0 => int 1 1 => int 4 2 => int 8 3 => int 7 4 => int 5<span style="color: #0000ff;">array</span> (size=2<span style="color: #000000;">) </span>'num' => int 5 'len' => int 10<span style="color: #0000ff;">boolean</span> <span style="color: #0000ff;">true</span><span style="color: #0000ff;">array</span> (size=4<span style="color: #000000;">) </span>0 => int 4 1 => int 8 2 => int 7 3 => int 5<span style="color: #0000ff;">array</span> (size=2<span style="color: #000000;">) </span>'num' => int 4 'len' => int 10
二 链表存储结构(n个节点链结成一个链表)
2.1 单链表(用数组模拟)
2.1.1 链表中第一个结点的存储位置为头指针(通常为了方便对链表进行操作,会在单链表的第一个结点前附设一个头结点)
注 头指针:指向链表第一个结点的指针,若链表有头结点,这是指向头结点的指针;无论链表是否为空,头指针不为空
头结点:放在第一元素的结点之前
<span style="color: #008000;">/*</span><span style="color: #008000;">* * 用一维数组模拟线性表 * array('data'=>data,'cur'=>cur) data为存放数据,cur为下个数组元素下标 </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">class</span><span style="color: #000000;"> Simple_Link { </span><span style="color: #008000;">//</span><span style="color: #008000;">数组长度</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$len</span> = 0<span style="color: #000000;">; </span><span style="color: #008000;">//</span><span style="color: #008000;">数组模拟</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$arr</span> = <span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008000;">//</span><span style="color: #008000;">数组中空闲的下标</span> <span style="color: #0000ff;">private</span> <span style="color: #800080;">$space_arr</span> = <span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 初始化结构 * @param Int $len 最大数组长度 * @param Array $arr 数组 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> __construct(<span style="color: #800080;">$len</span>, <span style="color: #0000ff;">Array</span> <span style="color: #800080;">$arr</span><span style="color: #000000;">) { </span><span style="color: #800080;">$this</span>->len = <span style="color: #800080;">$len</span><span style="color: #000000;">; </span><span style="color: #800080;">$length</span> = <span style="color: #008080;">count</span>(<span style="color: #800080;">$arr</span><span style="color: #000000;">); </span><span style="color: #800080;">$this</span>->arr[0]['data'] = <span style="color: #800080;">$length</span><span style="color: #000000;">; </span><span style="color: #800080;">$this</span>->arr[0]['cur'] = 0<span style="color: #000000;">; </span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$i</span> = 0; <span style="color: #800080;">$i</span> $length; ++<span style="color: #800080;">$i</span><span style="color: #000000;">) </span><span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>]['cur'] = <span style="color: #800080;">$i</span>+1; <span style="color: #008000;">//</span><span style="color: #008000;">模拟链表的指向</span> <span style="color: #0000ff;">if</span>(<span style="color: #800080;">$length</span><span style="color: #000000;">) </span><span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$length</span>]['cur'] = 0; <span style="color: #008000;">//</span><span style="color: #008000;">最后一个结点指针空</span> <span style="color: #0000ff;">for</span>(<span style="color: #800080;">$i</span> = <span style="color: #800080;">$length</span> + 1; <span style="color: #800080;">$i</span> $len-<span style="color: #800080;">$length</span> ; ++<span style="color: #800080;">$i</span>) <span style="color: #008000;">//</span><span style="color: #008000;">空闲数组</span> <span style="color: #008080;">array_unshift</span>(<span style="color: #800080;">$this</span>->space_arr,<span style="color: #800080;">$i</span><span style="color: #000000;">); } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取线性表元素: * 初始化$j从1开始 * 当$j<span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> get_elem(<span style="color: #800080;">$i</span><span style="color: #000000;">) { </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $i</span> > <span style="color: #800080;">$this</span>->arr[0]['data'<span style="color: #000000;">]) </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #800080;">$j</span> = 1<span style="color: #000000;">; </span><span style="color: #800080;">$cur</span> = <span style="color: #800080;">$this</span>->arr[0]['cur']; <span style="color: #008000;">//</span><span style="color: #008000;">指向第一个结点</span> <span style="color: #0000ff;">while</span>(<span style="color: #800080;">$j</span> $i<span style="color: #000000;">) { </span><span style="color: #800080;">$cur</span> = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$cur</span>]['cur'<span style="color: #000000;">]; </span>++<span style="color: #800080;">$j</span><span style="color: #000000;">; } </span><span style="color: #0000ff;">return</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$cur</span>]['data'<span style="color: #000000;">]; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 插入元素: * 初始化$j从1开始 * 当$j<span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> insert_elem(<span style="color: #800080;">$i</span>, <span style="color: #800080;">$elem</span><span style="color: #000000;">) { </span><span style="color: #800080;">$len</span> = <span style="color: #800080;">$this</span>->arr[0]['data'] + 1<span style="color: #000000;">; </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $i</span> > <span style="color: #800080;">$len</span><span style="color: #000000;">) </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #800080;">$j</span> = <span style="color: #800080;">$this</span>->malloc(); <span style="color: #008000;">//</span><span style="color: #008000;">获取空闲下标</span> <span style="color: #0000ff;">if</span>(!<span style="color: #800080;">$j</span><span style="color: #000000;">) </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$j</span>]['data'] = <span style="color: #800080;">$elem</span><span style="color: #000000;">; </span><span style="color: #800080;">$k</span> = 1<span style="color: #000000;">; </span><span style="color: #800080;">$index</span> = 0<span style="color: #000000;">; </span><span style="color: #800080;">$cur</span> = !<span style="color: #0000ff;">empty</span>(<span style="color: #800080;">$this</span>->arr[0]['cur']) ? <span style="color: #800080;">$this</span>->arr[0]['cur'] : 0; <span style="color: #008000;">//</span><span style="color: #008000;">指向第一个结点</span> <span style="color: #0000ff;">while</span>(<span style="color: #800080;">$k</span> $i<span style="color: #000000;">) { </span><span style="color: #008000;">//</span><span style="color: #008000;">记录当前cur和下一个cur</span> <span style="color: #800080;">$index</span> = <span style="color: #800080;">$cur</span><span style="color: #000000;">; </span><span style="color: #800080;">$cur</span> = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$index</span>]['cur'<span style="color: #000000;">]; </span>++<span style="color: #800080;">$k</span><span style="color: #000000;">; } </span><span style="color: #008000;">//</span><span style="color: #008000;">改变指针指向</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$index</span>]['cur'] = <span style="color: #800080;">$j</span><span style="color: #000000;">; </span><span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$j</span>]['cur'] = <span style="color: #800080;">$cur</span><span style="color: #000000;">; </span>++<span style="color: #800080;">$this</span>->arr[0]['data'<span style="color: #000000;">]; </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 删除元素: * 初始化$j从1开始 * 当$j<span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> delete_elem(<span style="color: #800080;">$i</span><span style="color: #000000;">) { </span><span style="color: #800080;">$len</span> = <span style="color: #800080;">$this</span>->arr[0]['data'<span style="color: #000000;">]; </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$i</span> $i</span> > <span style="color: #800080;">$len</span><span style="color: #000000;">) </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #800080;">$k</span> = 1<span style="color: #000000;">; </span><span style="color: #800080;">$index</span> = 0<span style="color: #000000;">; </span><span style="color: #800080;">$cur</span> = !<span style="color: #0000ff;">empty</span>(<span style="color: #800080;">$this</span>->arr[0]['cur']) ? <span style="color: #800080;">$this</span>->arr[0]['cur'] : 0; <span style="color: #008000;">//</span><span style="color: #008000;">指向第一个结点</span> <span style="color: #0000ff;">while</span>(<span style="color: #800080;">$k</span> $i<span style="color: #000000;">) { </span><span style="color: #008000;">//</span><span style="color: #008000;">记录当前cur和下一个cur</span> <span style="color: #800080;">$index</span> = <span style="color: #800080;">$cur</span><span style="color: #000000;">; </span><span style="color: #800080;">$cur</span> = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$index</span>]['cur'<span style="color: #000000;">]; </span>++<span style="color: #800080;">$k</span><span style="color: #000000;">; } </span><span style="color: #008000;">//</span><span style="color: #008000;">改变指针指向</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$index</span>]['cur'] = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$cur</span>]['cur'<span style="color: #000000;">]; </span><span style="color: #800080;">$this</span>->free(<span style="color: #800080;">$cur</span><span style="color: #000000;">); </span><span style="color: #0000ff;">unset</span>(<span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$cur</span><span style="color: #000000;">]); </span>--<span style="color: #800080;">$this</span>->arr[0]['data'<span style="color: #000000;">]; </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">true</span><span style="color: #000000;">; } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取空闲的结点下标,也就是相当于申请一个空结点 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">private</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> malloc() { </span><span style="color: #0000ff;">if</span>(<span style="color: #0000ff;">empty</span>(<span style="color: #800080;">$this</span>-><span style="color: #000000;">space_arr)) </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">false</span><span style="color: #000000;">; </span><span style="color: #0000ff;">return</span> <span style="color: #008080;">array_pop</span>(<span style="color: #800080;">$this</span>-><span style="color: #000000;">space_arr); } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 释放结点 * @param Int $cur 需要回收的结点下标 </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">private</span> <span style="color: #0000ff;">function</span> free(<span style="color: #800080;">$cur</span><span style="color: #000000;">) { </span><span style="color: #008080;">array_push</span>(<span style="color: #800080;">$this</span>->space_arr, <span style="color: #800080;">$cur</span><span style="color: #000000;">); } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 打印 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> print_arr() { </span><span style="color: #800080;">$i</span> = 0<span style="color: #000000;">; </span><span style="color: #0000ff;">if</span>(!<span style="color: #0000ff;">empty</span>(<span style="color: #800080;">$this</span>->arr[0]['data'<span style="color: #000000;">])) { </span><span style="color: #0000ff;">while</span>(<span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>]['cur'<span style="color: #000000;">]) { </span><span style="color: #800080;">$i</span> = <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>]['cur'<span style="color: #000000;">]; </span><span style="color: #0000ff;">echo</span> <span style="color: #800080;">$this</span>->arr[<span style="color: #800080;">$i</span>]['data'].' '<span style="color: #000000;">; } } } </span><span style="color: #008000;">/*</span><span style="color: #008000;">* * 获取长度 * @return </span><span style="color: #008000;">*/</span> <span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span><span style="color: #000000;"> get_len() { </span><span style="color: #0000ff;">return</span> <span style="color: #0000ff;">array</span>('num' => <span style="color: #800080;">$this</span>->arr[0]['data'] , 'len' => <span style="color: #800080;">$this</span>-><span style="color: #000000;">len); } } </span><span style="color: #800080;">$link</span> = <span style="color: #0000ff;">new</span> Simple_Link(10,<span style="color: #0000ff;">array</span><span style="color: #000000;">()); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->insert_elem(1,5<span style="color: #000000;">)); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->insert_elem(2,4<span style="color: #000000;">)); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->insert_elem(1,6<span style="color: #000000;">)); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>->delete_elem(3<span style="color: #000000;">)); </span><span style="color: #0000ff;">echo</span> <span style="color: #800080;">$link</span>-><span style="color: #000000;">print_arr(); </span><span style="color: #008080;">var_dump</span>(<span style="color: #800080;">$link</span>-><span style="color: #000000;">get_len()); 输出: </span><span style="color: #0000ff;">boolean</span> <span style="color: #0000ff;">true</span> <span style="color: #0000ff;">boolean</span> <span style="color: #0000ff;">true</span> <span style="color: #0000ff;">boolean</span> <span style="color: #0000ff;">true</span> <span style="color: #0000ff;">boolean</span> <span style="color: #0000ff;">true</span> 6 5 <span style="color: #0000ff;">array</span> (size=2<span style="color: #000000;">) </span>'num' => int 2 'len' => int 10