对顺序表的操作,添加与删除元素。

增加元素

如下图所示  对顺序列表 Li [1328,693,2529,254]  添加一个元素 111 ,有三种方式:

a)尾部端插入元素,时间复杂度O(1);    保证了原始顺序列表的顺序。

b)非保序的加入元素(不常见),时间复杂度O(1);   打乱了原始顺序列表的顺序。

c)保需的元素插入,时间复杂度O(n);    保证了原始顺序列表的顺序。

删除元素

如下图所示  对顺序列表 Li [1328,693,2529,254]  删除元素 ,有三种方式:

a)删除表尾元素,时间复杂度O(1);

b)非保序的元素删除,时间复杂度O(1);

c)保序的元素删除,时间复杂度O(n);  比如上图删除1号元素。

list存储数据,允许不同类型的数据作为元素:如,Li [ 121, 'hello', 3.14, 1000 ], 因此List采用元素外置的方式来做。

元素外置的方式:可以理解为,列表list中,存储的是各个元素的地址,各个元素是外置到list外部, 每个元素的地址对应外部的元素。如下图:

支持顺序表存储区扩充的,称作动态顺序表

PHP代码实现动态的顺序表:

  1 <?php
2 /**
3 * Class Sequence
4 * desc:顺序表的实现:
5 * 顺序表:在内存中元素是顺序存储的,除了首部元素和尾部元素,其余元素是一一紧凑相连的;一般用一维数组表示。
6 * 特点:顺序表元素是外置的,顺序表中只存元素的地址;顺序表中的元素可能是多种数据类型类型的元素
7 * getElem 获取元素的位置
8 * getListLen 获取顺序表的长度
9 * getPriorElem 获取前一个元素
10 * getNextElem 获取后一个元素
11 * InsertList 在第index个位置插入元素elem,返回新的顺序表
12 * DeleteList 在第index个位置删除elem,返回新的顺序表
13 */
14
15 class Sequence
16 {
17 public $seqArr;
18 public $length;
19 public function __construct($arr)
20 {
21 $this->seqArr = $arr;
22 $this->length = count($arr);
23 }
24
25 //获取顺序表List中给定元素
26 public function getElem($index)
27 {
28 if($index<0 || $index==0 || $index>$this->length)
29 {
30 return "Error!";
31 }
32 return $this->seqArr[$index];
33 }
34
35 //获取顺序表List的长度
36 public function getListLen($arr)
37 {
38 return $this->length;
39 }
40
41 //获取顺序表List中给定元素位置
42 public function getLocateElem($elem)
43 {
44 if(in_array($elem,$this->seqArr))
45 {
46 for ($i=0;$i<$this->length;$i++)
47 {
48 if($this->seqArr[$i] == $elem)
49 {
50 return $i+1;
51 }
52 }
53 }
54 else
55 {
56 return "Error! elem not in Sequence!";
57 }
58 }
59
60 //获取给定元素在顺序表List中的上一个元素
61 public function getPriorElem($elem)
62 {
63 if(in_array($elem,$this->seqArr))
64 {
65 for ($i=0;$i<$this->length;$i++)
66 {
67 if($this->seqArr[$i] == $elem && $i==0)
68 {
69 return "Error: This is first Elem in Sequence!";
70 }
71 elseif($this->seqArr[$i] == $elem)
72 {
73 return $this->seqArr[$i-1];
74 }
75 }
76 }
77 else
78 {
79 return "Error!";
80 }
81 }
82
83 //获取给定元素在顺序表List中的下一个元素
84 public function getNextElem($elem)
85 {
86 if(in_array($elem,$this->seqArr))
87 {
88 for ($i=0;$i<$this->length;$i++)
89 {
90 if($this->seqArr[$i] == $elem && $i==($this->length-1))
91 {
92 return "Error: This is final Elem in Sequence!";
93 }
94 elseif($this->seqArr[$i] == $elem)
95 {
96 return $this->seqArr[$i+1];
97 }
98 }
99 }
100 else
101 {
102 return "Error! elem not in Sequence!";
103 }
104
105 }
106
107 //顺序表第index 中新增一个元素elem,返回新的顺序表
108 public function InsertList($index,$elem)
109 {
110 if($this->length == 0 || $index > $this->length || $index <0)
111 {
112 return "Error !";
113 }
114 for ($i=($this->length-1);$i>$index-1;$i--)
115 {
116 $this->seqArr[$i+1] = $this->seqArr[$i];
117 }
118 $this->seqArr[$index] = $elem;
119 $this->length = $this->length+1;
120 return $this->seqArr;
121 }
122
123 //顺序表删除第index中一个元素elem,返回新的顺序表
124 public function DeleteList($index)
125 {
126 if($this->length == 0 || $index > $this->length || $index <0)
127 {
128 return "Error !";
129 }
130 unset($this->seqArr[$index]);
131 $this->length--;
132 return $this->seqArr;
133 }
134 }
135
136 $arr = [6,'好','你',9,3.14];
137 $se = new Sequence($arr);
138 //var_dump($se->getElem(1)); echo"\r\n";
139 //var_dump($se->getListLen($arr)); echo"\r\n";
140 //var_dump($se->getLocateElem(9)); echo"\r\n";
141 //var_dump($se->getPriorElem(9)); echo"\r\n";
142 //var_dump($se->getNextElem(9)); echo"\r\n";
143 //print_r($se->InsertList(1,81)); echo"\r\n";
144 print_r($se->DeleteList(3)); echo"\r\n";

顺序表添加与删除元素以及 php实现顺序表实例的更多相关文章

  1. Arrays.asList () 不可添加或删除元素的原因

    Java中奖数组转换为List<T>容器有一个很方便的方法 Arrays.asList(T ... a),我通过此方法给容器进行了赋值操作,接着对其进行 添加元素,却发现会抛出一个(jav ...

  2. JavaScript向select下拉框中添加和删除元素

    JavaScript向select下拉框中添加和删除元素 1.说明 a   利用append()方法向下拉框中添加元素 b   利用remove()方法移除下拉框中最后一个元素 2.设计源码 < ...

  3. js进阶 9-11 select选项框如何动态添加和删除元素

    js进阶 9-11 select选项框如何动态添加和删除元素 一.总结 一句话总结: 二.js进阶 9-11 select选项框如何动态添加和删除元素 1.案例说明 2.相关知识 Select 下拉列 ...

  4. javascript数组在指定位置添加和删除元素

    在JavaScript中,Array对象提供了一个强大的splice()方法,利用这个方法可以达到在数组的指定位置添加和删除元素的目的. 指定位置删除元素 要在指定位置删除元素,可以使用splice( ...

  5. 4. 理解Update、Enter、Exit 与 添加、删除元素

    理解Update.Enter.Exit 与 添加.删除元素 在使用data()绑定数据时,例如:现在我们有一个数组[3,6,9,12,15],我们可以将数组每一项与一个<p>绑定,但是,现 ...

  6. (转载)php数组添加、删除元素的方法

    (转载)http://www.phpgs.com/html/php/phpjichu/20120130440.html 带来一篇php 数组 添加元素.删除元素的方法的文章,有需要的php学习者参考下 ...

  7. python中List添加、删除元素的几种方法

    一.python中List添加元素的几种方法 List 是 Python 中常用的数据类型,它一个有序集合,即其中的元素始终保持着初始时的定义的顺序(除非你对它们进行排序或其他修改操作).在Pytho ...

  8. Python -- 修改、添加和删除元素

    大多数列表将是动态的,这意味着列表创建后,将随着程序的运行增删元素. 修改列表元素 修改列表元素的语法与访问列表元素的语法类似.要修改列表元素,可指定表名和要修改的元素指引,再指定该元素的新值. #代 ...

  9. JQUERY添加、删除元素、eq()方法;

    一.jQuery - 添加元素 1.append() - 在被选元素内部的结尾插入指定内容 2.prepend() - 在被选元素内部的开头插入指定内容 3.after() - 在被选元素之后插入内容 ...

随机推荐

  1. 二分图匹配——p3386 p2071 p2319 p1129(矩阵游戏)

    ---恢复内容开始--- 二分图,就是给你一个图,可以将点分为两部分,每一部分的点都能唯一映射到另一个集合里,也就是有连边: 注:以下转自 http://blog.csdn.net/dark_scop ...

  2. python下pip 安装 pyautogui报错Command "python setup.py egg_info" failed with error code 1 in C:\Users\Administrator\AppData\Local\Temp\pip-install-svhtepho\pygetwindow\

    python装的3.6 64位,使用命令pip install pyautogui 或者pip install -U pyautogui 都失败了 报错如下: Command "python ...

  3. redis5种数据结构讲解及使用场景

    string  list  hash set zset  探究 Redis 4 的 stream 类型 redis提供了5中数据结构,理解每种数据结构的特点对于redis开发运维非常重要.  一.字符 ...

  4. TynSerial图片序列(还原)

    TynSerial图片序列(还原) 笔者以生成图形验证码为例. function TForm1.VerifyCode(image: TImage): string; // 生成验证码和图像 var u ...

  5. Win+数字快速启动/切换指定程序

    Windows键+数字,可以快速启动任务栏上的程序 按下按下Win+4桌面将切换到排序第4的程序:页也就是谷歌浏览器. 今天刚发现这个小功能.   文章来源:外星人来地球 欢迎关注,有问题一起学习欢迎 ...

  6. ORACLE中声明变量:define variable declare

    在sqlplus 环境中,声明变量的关键字:define variable declare 一.define关键字(host变量) host变量的作用是一个替换作用,是主机环境与oracle进行交互的 ...

  7. Vue 相关开源项目库汇总

    element ★9395 - 饿了么出品的Vue2的web UI工具套件 Vux ★6835 - 基于Vue和WeUI的组件库 vueAdmin ★569 - 基于vuejs2和element的简单 ...

  8. Mac下安装python2和python3共存

    一般是python2默认安装了,python3没有安装,这时候一般使用命令:brew install python3 进行安装 这里有个基础知识要记录一下,就是不同方法安装python的路径是不一样的 ...

  9. redis配置文件讲解

    #redis.conf # Redis configuration file example. # ./redis-server /path/to/redis.conf ############### ...

  10. rand随机函数

    1.rand() rand()函数是使用线性同余法做的,它并不是真的随机数,因为其周期特别长,所以在一定范围内可以看成随机的. rand()函数不需要参数,它将会返回0到RAND_MAX之间的任意的整 ...