线性表的顺序储存结构
线性表的顺序存储结构是一种什么存储结构

线性表的顺序存储结构是一种什么存储结构线性表中数据元素之间的关系是一对一的关系,即除了第一个和最后一个数据元素之外,其它数据元素都是首尾相接的(注意,这句话只适用大部分线性表,而不是全部。
比如,循环链表逻辑层次上也是一种线性表(存储层次上属于链式存储),但是把最后一个数据元素的尾指针指向了首位结点)。
我们说“线性”和“非线性”,只在逻辑层次上讨论,而不考虑存储层次,所以双向链表和循环链表依旧是线性表。
在数据结构逻辑层次上细分,线性表可以分成通常线性表和受到限制线性表。
通常线性表也就是我们通常所说的“线性表”,可以民主自由的删掉或嵌入结点。
受到限制线性表主要包含栈和队列,受到限制则表示对结点的操作方式受限制。
线性表的逻辑结构简单,便于实现和操作。
因此,线性表这种数据结构在实际应用中是广泛采用的一种数据结构。
线性表就是一种常用的数据结构,以下了解线性表及其顺序存储,并对栈和队列及它们的顺序同时实现得出了详尽的设计叙述。
在实际应用中,线性表都是以栈、队列、字符串等特殊线性表的形式来使用的。
由于这些特殊线性表都具有各自的特性,因此,掌握这些特殊线性表的特性,对于数据运算的可靠性和提高操作效率都是至关重要的。
线性表就是一个线性结构,它就是一个所含n≥0个结点的非常有限序列,对于其中的结点,存有且仅有一个已经开始结点没前驱但存有一个后继结点,存有且仅有一个终端结点没后继但存有一个前驱结点,其它的结点都存有且仅有一个前驱和一个后继结点。
通常地,一个线性表可以则表示成一个线性序列:k1,k2,…,kn,其中k1就是已经开始结点,kn就是终端结点。
是一个数据元素的有序(次序)集1、子集中必存有唯一的一个“第一元素”;2、集合中必存在唯一的一个“最后元素” ;3、除最后一个元素之外,均存有唯一的后继(后件);4、除第一个元素之外,均有唯一的前驱(前件)。
由n(n≥0)个数据元素(结点)a1,a2,…,an共同组成的非常有限序列。
3线性表及其顺序存储结构

1.3线性表及其顺序存储结构1.线性表的基本概念线性表是由n个数据元素组成的一个有限序列,表中的每一个数据元素,除了每一个外,有且只有一个前件,除了最后一个外,有且只有一个后件。
即线性表或是一个空表。
显然线性表是一种线性结构,数据元素在线性表中的位置只取决于它们自己的序号,即数据元素之间的相对位置是线性的。
非空线性表有如下一些结构特征:(1)有且只有一个根结点,它无前件;(2)有且只有一个根结点,它无后件;(3)除了根结点与终端结点外,其他所有结点有且只有一个前件,也只有且只有一个后件。
2.线性表的存储结构线性表的顺序存储结构具有以下两个特征:(1)线性表中所有元素所占的存储空间是连续的;(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。
由此可以看出,在线性表的顺序存储结构中,其前件和后件两个元素在存储空间中是紧邻的,且其前件元素一定存储在后件元素的前面。
在程序设计语言中,通常定义一个一维数组来表示线性表的顺序存储看见。
因为程序设计语言中的一维数组与计算机中的实际的存储空间结构是类似的,这就便于用程序设计语言对线性表进行各种运算处理。
在线性表的顺序存储结构中,可以对线性表进行各种处理。
主要的运算有如下几种:(1)在线性表的指定位置处加入一个新的元素;(2)在线性表中删除指定的元素;(3)在线性表中查找某个特定的元素;(4)对线性表中的元素进行整序;(5)按要求将一个线性表分解成多个线性表;(6)按要求将多个线性表合并成一个线性表;(7)复制一个线性表;(8)逆转一个线性表等。
3.顺序表的插入运算设长度为n的线性表为(a1,a2,a3,a4,…,ai, …,an)现要在线性表的第i个元素ai之前插入一个新元素b,插入后得到长度为n+1的线性表为(a1,a2,a3,a4,…,aj,aj+1, …,an,an+1)则插入前后的两线性表中的元素满足如下关系:a j0<j<iaj= b j=ia j-1i<j<n在一般情况下,要在第i(1<i<n+1)元素之间插入一个新元素时,首先要从最后一个元素开始,直到第i个元素之间共n-i+1个元素依次向后移动一个位置,移动结束后,第i个位置就被空出,然后将新元素插入到第i项。
数据结构22 线性表的顺序存储结构

② 按顺序存储方式存储的线性表具有顺序存储结构, 一般称之为顺序表。换言之,在程序中采用定长的 一维数组,按顺序存储方式存储的线性表,被称为 顺序表.
线性表顺序存储结构的缺点 线性表容量不易改变,插入和删除结点较繁琐, 需移动元素调整一批结点的地址。
问题:由于线性表中元素的数目可能改变,因此 定义数组时要做如何的考虑呢? 定义大小合适的数组。
15
A的当前长度为 n, n m; 删除下标为 k 的结点 */
D1.[k合法?] IF (k 0 OR k n1 OR n0) THEN (PRINT“k不合法”. 终止本算法.).
D2.[删除] FOR ik1 TO n1 DO A[i1]A[i]. n n1. ▌
13
时间复杂性分析:
删除操作中与时间关系紧密的基本运算是什么? 元素移动
7
序号 元素
序号 元素
0 12
0 12
1 13
1 13
2 21
2 21
插入25 3 24
3 24
4 28
4 25
5 30
5 28
6 42 7 77
6 30 7 42
8 77
8
//采用ADL算法描述语言描述算法
算法 Insert(A , k , X) /* 设顺序表 A 的最大长度为 m,A
当前长度为 n(A[0], A[1], , A[n1]),且始终有 n m; 在下标为 k 的结点后插入值为 X 的结点 */
数据结构实验报告1线性表的顺序存储结构

数据结构实验报告1线性表的顺序存储结构数据结构实验报告1线性表的顺序存储结构第一章引言线性表是计算机中最常见的数据结构之一,它是一种有序的数据元素集合,其中的数据元素之间具有一对一的关系。
线性表的存储结构有多种方式,其中顺序存储结构是最简单的一种,它使用一段连续的存储单元来存储线性表中的元素。
第二章顺序存储结构的定义顺序存储结构是将线性表中的元素按照其逻辑顺序依次存储在一块连续的存储空间中。
顺序存储结构的特点是可以快速地访问任意位置的元素,但插入和删除操作需要移动大量的元素。
第三章顺序存储结构的实现1.存储空间的分配顺序存储结构通常使用数组来实现,数组的长度应该大于等于线性表的长度,以防止溢出。
存储空间的分配可以使用静态分配或动态分配两种方式来实现。
2.线性表的初始化初始化线性表时,需要设置线性表的长度和当前元素的个数。
3.线性表的增删改查操作●插入操作:________在指定位置插入一个元素时,需要将插入位置之后的元素依次后移,给待插入的元素腾出位置。
●删除操作:________删除指定位置的元素时,需要将删除位置之后的元素依次前移,覆盖删除位置上的元素。
●修改操作:________修改指定位置的元素时,直接对该位置上的元素进行修改即可。
●查找操作:________根据指定的元素值,查找其在顺序存储结构中的位置。
4.线性表的遍历操作遍历操作可以按照顺序访问线性表中的每个元素,可以使用循环结构实现遍历操作。
第四章顺序存储结构的优缺点分析1.优点:________可以快速地访问任意位置的元素,节省存储空间。
2.缺点:________插入和删除操作需要移动大量的元素,不适用于频繁插入和删除的场景。
第五章实验过程和结果分析在本次实验中,我们以顺序存储结构为基础,实现了线性表的增删改查操作,并进行了遍历操作。
通过实验,我们发现顺序存储结构在查询操作上有较好的性能,但在插入和删除操作上的性能较差。
第六章附件本文档涉及的附件详见附件文件。
计算机基础知识:线性表的顺序存储结构

官方微信:【zjsydwks 】
地址:杭州市文三路477号华星科技大厦三楼 事业单位微信号:zjsydwks
计算机基础知识:线性表的顺序存储结构
【导语】在事业单位考试中,计算机专业知识的复习向来是考生复习备考阶段的一大重点,其中中公事业单位考试网为计算机基础知识的复习为考生提供知识点梳理,帮助考生备考!
假设线性表中的第一个数据元素的存储地址(即首地址)为 ADR(a1),每一个数据元素占k 个字节,则线性表中第i 个元素ai 在计算机存储空间中的存储地址为:ADR(ai)=ADR(a1)+(i-1)k 。
长度为n 的线性表在计算机中的顺序存储结构如图3-1所示。
以上是中公事业单位考试网为考生梳理计算机基础知识点,供大家学习识记!
最新招考公告、备考资料就在浙江事业单位考试网。
线性表的顺序存储结构

线性表的顺序存储结构线性表的顺序存储结构相关概念举个栗⼦:⼤学的时候,宿舍有⼀个同学,帮⼤家去图书馆占座。
他每次去图书馆,挑⼀个好地⼉,把他书包⾥的书,⼀本⼀本按座位放好,若书不够,再把⽔杯,⽔笔都⽤上,长长⼀排,九个座硬是被他占了。
1. 顺序存储的定义线性表的顺序存储结构,指的是⽤⼀段地址连续的存储单元依次存储线性表的数据元素。
⽰意图:2. 顺序存储⽅式线性表的顺序存储结构,其实就和刚才图书馆占座的例⼦⼀样,就是在内存中找了块地⼉,通过占位的形式,把⼀定内存空间给占了,然后把相同数据类型的数据元素依次存放在这块空地中。
既然线性表的每个数据元素的类型都相同,所以可以⽤⼀维数组来实现顺序存储结构,即把第⼀个数据元素存到数组下标为0的位置中,接着把线性表相邻的元素存储在数组中相邻的位置。
这⾥有⼏个关键的地⽅:1)为了建⽴⼀个线性表,要在内存中找⼀块地,这块地的第⼀位置就⾮常关键,他是存储空间的起始位置2)数组的长度就是这个最⼤存储容量3)线性表的当前长度3. 数据长度与线性表长度区别1)数组的长度是存放线性表的存储空间的长度,存储分配后这个量⼀般是不变的。
当然,⼀般⾼级语⾔是可以通过编程⼿段实现动态分配数组,不过这会带来性能上的损耗。
2)线性表的长度是线性表中数据元素的个数,随着线性表插⼊和删除操作的进⾏,这个量是变化的。
在任意时刻,线性表的长度应该⼩于等于数组的长度。
4. 地址计算⽅法数组是从0开始第⼀个下标的,于是线性表的第i个元素是要存储在数组下标为i-1的位置,即数据元素的序号和存放它的数组下标之间存在对应关系:存储器中的每个存储单元都有⾃⼰的编号,这个编号称为地址。
假设每个数据元素占⽤的都是c个存储单元,那么每个数据元素地址可通过公式计算得到: LOC(ai)=LOC(a1)+(i-1)*c它的存取时间性能为O(1)。
我们通常把具有这⼀特点的存储结构称为随机存取结构。
相关操作1. 获得元素操作(GetElem)获取元素的思路:1)考虑边界问题,顺序线性表L已存在(⾮空表),并且i必须在1<=i<=ListLength(L)范围内,否则抛出异常2)将数值下标为i-1的值返回即可C语⾔的实现如下:1// 获得元素操作2#define OK 13#define ERROR 04#define TRUE 15#define FALSE 06 typedef int Status;7/*Status是函数的类型,其值是函数结果状态代码,如OK等*/8/*初始条件:顺序线性表L已存在,1<=i<=ListLength(L)*/9/*操作结果:⽤e返回L中第i个数据元素的值*/1011 Status GetElem(SqList L, int i, ElemType *e)12 {13if (L.length == 0 || i < 1 || i > L.length)14return ERROR;15 *e = L.data[i-1];16return OK;17 }PHP的实现如下:1 <?php2class Seqlist{34private$seq_list; //顺序表5/**6 * 顺序表初始化7 *8 * @param mixed $seq_list9 * @return void10*/11public function __construct($seq_list=array()){12$this->seq_list = $seq_list;13 }1415/**16 * 返回顺序表元素个数17 *18 * @return int19*/20public function listLength(){21return count($this->seq_list);22 }2324/**25 * 返回顺序表中下标为i的元素值26 *27 * @param int i28 * @return mixed 如找到返回元素值,否则返回false29*/30public function getElem($i){31if ($this->seq_list && $i > 0 && $i <= $this->listLength()) {32return$this->seq_list[$i-1];33 }else{34return false;35 }36 }37 }2. 插⼊操作插⼊算法的思路:1)如果插⼊位置不合理(1<=i<=ListLength(L)+1),抛出异常说明:最好的情况就是,插⼊的位置为末尾:ListLength(L)+1(不是数组下标),这个时候不⽤移动元素,时间复杂度是O(1) 2)如果线性表长度⼤于等于数组长度,则抛出异常或动态增加容量3)从最后⼀个元素开始向前遍历到第i个位置,分别将它们都向后移动⼀个位置4)将要插⼊元素填⼊位置 i 处5)表长加1C语⾔的实现如下:1// 插⼊操作2#define OK 13#define ERROR 04#define TRUE 15#define FALSE6 typedef int Status;7/*初始条件:顺序线性表L已存在,1<=i<=ListLength(L)*/8/*操作结果:在L中第i个位置之前插⼊新的数据元素e,L的长度加1*/910 Status ListInsert(SqList *L, int i, ElemType e)11 {12int k;13if (L->length == MAXSIZE) /*顺序线性表已经满*/14return ERROR;15if (i < 1 || i > L->length + 1) /*当i不在范围内时*/16return ERROR;1718if (i <= L->length) /*若插⼊数据位置不在表尾*/19 {20for (k = L->length - 1; k >= i - 1; k--) /*将要插⼊位置后数据元素向后移动⼀位*/21 {22 L->data[k + 1] = L->data[k];23 }24 }25 L->data[i - 1] = e; /*将新元素插⼊*/26 L->length++;27return OK;28 }PHP的实现如下:1 <?php2class Seqlist{34private$seq_list; //顺序表5/**6 * 顺序表初始化7 *8 * @param mixed $seq_list9 * @return void10*/11public function __construct($seq_list=array()){12$this->seq_list = $seq_list;13 }1415/**16 * 在指定位置 i 插⼊⼀个新元素 $value17 *18 * @param int $i19 * @param mixed $value20 * @return bool 插⼊成功返回 true, 否则返回 false21*/22public function listInsert($i, $value){23// 三种情况:插⼊位置不合理24if ($i > $this->listLength()+1 || $i < 1) {25return false;26 }elseif ($i == $this->listLength()+1) {27// 最好的情况:元素插⼊到最后⼀个位置,不需要移动元素,时间复杂度为O(1)28$this->seq_list[$i-1] = $value;29 }else{30// 从 $i-1 到最后的元素位置向后移动⼀位31for ($k = $this->listLength()-1; $k >= $i-1; $k--) {32$this->seq_list[$k+1] = $this->seq_list[$k];33 }34$this->seq_list[$i-1] = $value;35 }3637return true;38 }39 }这⾥有⼀个疑问,因为前⾯我们提到了:在任意时刻,线性表的长度应该⼩于数组的长度。
第2章线性表第2讲-线性表的顺序存储结构

a1 a2
e 插入完成
1ห้องสมุดไป่ตู้/23
插入算法如下:
15/23
对于本算法来说,元素移动的次数不仅与表长L->length=n
有关,而且与插入位置i有关:
当i=n+1时,移动次数为0; 当i=1时,移动次数为n,达到最大值。
其中data成员存放元素,length成员存放线性表的实际 长度。
说明:注意逻辑位序和物理位序相差1。
3/23
1、建立顺序表
a[0..n-1] 顺序表L ─ 整体创建顺序表。
传递顺序表 指针
4/23
算法参数说明
顺序表指针的含义
SqList *L; L=(SqList *)malloc(sizeof(SqList)); 顺序表的空间
算法最好时间复杂度为O(1)
算法最坏时间复杂度为O(n)
16/23
平均情况分析:
a1 a2 … ai ai+1 … an
在线性表L中共有n+1个可以插入元素的地方
1 在插入元素ai时,若为等概率情况,则pi = n 1
此时需要将ai~an的元素均后移一个位置,共移动n-i+1个 元素。 所以在长度为n的线性表中插入一个元素时所需移动元 素的平均次数为:
20/23
平均情况分析: a1 a2 … ai ai+1 … an
在线性表L中共有n个可以删除元素的地方
在删除元素ai时,若为等概率情况,则pi = n 此时需要将ai+1~an的元素均前移一个位置,共移动 n-(i+1)+1=n-i个元素。 所以在长度为n的线性表中删除一个元素时所需移动元 素的平均次数为:
线性表之顺序存储结构

线性表之顺序存储结构数据结构和算法是程序设计的灵魂。
坦诚的说,我在这方面是弱的可以。
虽然工作这么多年了,因为种种借口,这块知识一直是我的痛处。
曾经在面试时大言不惭的说,这些知识在工作中很少用到,所以当年学习的东西早就还给学校了。
其实不然,失去了灵魂的程序员如我,总是要逆袭的。
所以以后的学习中会有一些如孩童笔记般的文章出现在我的blog中,请大师们不要嘲笑,要提携。
定义线性表可以说是最简单的数据结构,它的描述为:n个数据元素的有限序列。
记为:L=(a1,a2,...,an)按照存储结构它又可以分为顺序存储结构和链式存储结构。
而其中线性表的顺序存储结构是最简单最常用的数据结构:用一段连续地址依次存储表中的数据元素。
看到这里,我们会自然的联想到C语言中的数组。
下面我要实现的是线性表中的元素为整型的顺序存储结构,及它的主要运算:增删查。
先来简单的定义一下这个线性表的顺序存储结构:#define MAXLENGTH 20struct sequencelist{int data[MAXLENGTH];int length;};其中data数组为这个线性表的主要部分,数据元素就存在于此数组中,而对这个线性表的操作都是基于这个数组。
length是这个线性表的一个属性,表示这个线性表包含元素的个数。
增:线性表的插入操作对线性表的插入就是对data数组的插入,然后将其length增加。
//insert oprationint insert(struct sequencelist *list,int index,int element){int length = list->length;if(length ==0 || index < 0 || index > length || length >= MAXLENGTH) return ERROR;list->data[index] = element;for(int i = length - 1;i>index;i--){list->data[i+1] = list->data[i];}list->length++;return OK;}删:线性表的删除操作类似增的相反操作。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
重庆交通大学《算法与数据结构》课程实验报告班级:计算机科学与技术2014级2班实验项目名称:线性表的顺序储存结构实验项目性质:实验所属课程:算法与数据结构实验室(中心):B01407****:***实验完成时间:2016 年 3 月21 日一、实验目的1、实现线性表的顺序存储结构2、熟悉C++程序的基本结构,掌握程序中的头文件、实现文件和主文件之间的相互关系及各自的作用3、熟悉顺序表的基本操作方式,掌握顺序表相关操作的具体实现二、实验内容及要求对顺序存储的线性表进行一些基本操作。
主要包括:(1)插入:操作方式为在指定元素前插入、在指定元素之后插入、在指定位置完成插入(2)删除:操作方式可分为删除指定元素、删除指定位置的元素等,尝试实现逻辑删除操作。
(3)显示数据(4)查找:查询指定的元素(可根据某个数据成员完成查询操作)(5)定位操作:定位指定元素的序号(6)更新:修改指定元素的数据(7)数据文件的读写操作等。
其它操作可根据具体需要自行补充。
要求线性表采用类的定义,数据对象的类型自行定义。
三、实验设备及软件VC6.0四、设计方案㈠题目线性表的顺序存储结构㈡设计的主要思路1、新建SeqList.h头文件,定义SeqList模板类2、设计类数据成员,包括:T *data(用于存放数组)、int maxSize(最大可容表项的项数)、int last(当前已存表项的最后位置)3、设计类成员函数,主要包括:int search(T& x)const;//搜索x在表中位置,函数返回表项序号int Locate(int i)const;//定位第i个表项,函数返回表项序号bool getData(int i,T& x)const;//去第i个表项的值void setData(int i,T& x)//用x修改第i个表项的值bool Insert(int i,T& x);//插入x在第i个表项之后bool Remove(int i,T& x); //删除第i个表项,通过x返回表项的值bool IsEmpty();//判表空否,空则返回true;否则返回falsebool IsFull();//判表满否,满则返回true;否则返回falsevoid input(); //输入void output();//输出void ofile();/存储在文件中void ifile();//读取文件并显示㈢主要功能1、建立新表2、对表进行插入(指定元素前、后以及指定位置插入)、删除(指定元素删除及指定位置删除)、修改等操作3、显示当前操作表的全部内容4、存储在文件中5、从文件中读取表五、主要代码㈠SeqList.h中的主要代码:1、类成员声明部分:protected:T *data; //存放数组int maxSize; //最大可容纳表项的项数int last; //当前已存表项的最后位置(从0开始)void reSize(int newSize); //改变data数组空间大小public:SeqList(int sz = defaultSize); //构造函数SeqList(SeqList<T>& L); //复制构造函数~SeqList(){delete[] data;} //析构函数int Size()const{return maxSize;} //计算表最大可容纳表项个数int Length()const{return last+1;} //计算表长度int search(T& x)const; //搜索x在表中位置,函数返回表项序号int Locate(int i)const; //定位第i个表项,函数返回表项序号bool getData(int i,T& x)const //去第i个表项的值{if(i>0&&i<=last+1){x=data[i-1];return true;}else return false;}void setData(int i,T& x) //用x修改第i个表项的值{if(i>0&&i<=last+1) data[i-1]=x;}bool Insert(int i,T& x); //插入x在第i个表项之后bool Remove(int i,T& x); //删除第i个表项,通过x返回表项的值bool IsEmpty(){return (last == -1)?true:false;} //判表空否,空则返回true;否则返回falsebool IsFull(){return (last == maxSize-1)?true:false;} //判表满否,满则返回true;否则返回falsevoid input(); //输入void output(); //输出SeqList<T>operator=(SeqList<T>& L); //表整体赋值void ofile(); //存储在文件中void ifile(); //读取文件并显示2、部分成员函数//搜索函数:在表中顺序搜索与给定值x匹配的表项,找到则函数返回该表项是第几个元素//否则函数返回0,表示搜索失败template<class T>int SeqList<T>::search(T& x)const{for(int i = 0;i <= last; i++)if(data[i] == x) return i+1; //顺序搜索return 0; //搜索失败}//定位函数:template<class T>int SeqList<T>::Locate(int i)const{if(i >= i&&i <= last+1) return i ;else return 0;}//插入函数//将新元素x插入到表中第i(i>=0&&i<=last+1)个表项之后,函数返回插入成功的信息,若//插入成功,则返回true;否则返回false.i=0是虚拟的,实际上是插入的第1个元素位置template<class T>bool SeqList<T>::Insert(int i,T& x){if(last == maxSize-1) return false; //表满,不能插入if(i<0 || i>last+1) return false; //参数i不合理,不能插入for(int j = last ;j >=i;j--) //依次后移,空出第i号位置data[j+1] = data[j];data[i] = x; //插入last++; //最后位置+1return true; //插入成功}//删除函数//从表中删除第i个表项,通过应用型参数x返回删除的元素值,函数//返回删除成功的信息,如删除成功则返回true,否则返回falsetemplate<class T>bool SeqList<T>::Remove(int i,T& x){if(last == -1 )return false;if(i<1 || i>last+1)return false;x = data[i-1];for(int j = i;j <= last;j++)data[j-1] = data[j];last--;return true;}//输入函数//从标准输入逐个数据输入,建立顺序表template<class T>void SeqList<T>::input(){cout<<"开始建立顺序表,请输入表中的元素个数:";while(1){cin>>last;if(last<=maxSize-1) break;cout<<"表元素个数有误,范围不能超过"<<maxSize<<":";}for(int i = 0;i < last;i++){cout<<"#"<<i+1<<":";cin>>data[i];}}//输出函数template<class T>void SeqList<T>::output(){cout<<"顺序表当前元素最后的位置为:"<<last<<endl;for(int i = 0;i < last;i++)cout<<"#"<<i+1<<":"<<data[i]<<endl;}//存储在文件中template<class T>void SeqList<T>::ofile(){ofstream f1("Test1.txt",ios::out);if(!f1){cout<<"存储文件失败!"<<endl;exit(1);}for(int i = 1;i < last+1;i++)f1.write((char*) &data[i-1],sizeof(data[i-1]));cout<<"存储成功!"<<endl;f1.close();}//读取文件并打印出文件内容template<class T>void SeqList<T>::ifile(){ifstream f2("Test1.txt",ios::binary);if(!f2){cout<<"打开文件失败!"<<endl;exit(1);}cout<<"文件内容如下:"<<endl;for(int i = 1;!f2.eof();i++){f2.read((char*)&data[i-1],sizeof(data[i-1]));}for(int j = 1;j < i-1;j++)cout<<"#"<<j<<":"<<data[j-1]<<endl;f2.close();}㈡测试主函数1、插入功能,对不同位置的插入通过修改函数Insert(int i,x)第一形参实现,位置可通过成员函数search(x)确定case 3:{//指定元素后插入int x,y;cout<<"请输入指定元素:";cin>>x;cout<<"请输入要插入的元素:";cin>>y;Seq.Insert(Seq.search(x),y);break;}case 4:{//指定位置插入int i,x;cout<<"请输入插入的位置:";cin>>i;cout<<"请输入要插入的元素:";cin>>x;Seq.Insert(i,x);break;}case 5:{//按内容删除指定元素int i,x;cout<<"请输入要删除的元素内容:";cin>>x;i = Seq.search(x); //指定元素位置if(Seq.Remove(i,x)) cout<<"删除成功!"<<endl;else cout<<"删除失败!"<<endl;break;}2、删除功能,指定序号删除直接调用Remove(i,x)即可实现,指定表项的内容删除可通过search(x)函数返回得到该表项的序号,再通过Remove(i,x)实现case 5:{//按内容删除指定元素int i,x;cout<<"请输入要删除的元素内容:";cin>>x;i = Seq.search(x); //指定元素位置if(Seq.Remove(i,x)) cout<<"删除成功!"<<endl;else cout<<"删除失败!"<<endl;break;}case 6:{//按位置删除指定元素int i,x;cout<<"请输入要删除的元素序号:";cin>>i;if(Seq.Remove(i,x)) cout<<"删除成功,删除的元素是:"<<x<<endl;else cout<<"删除失败!"<<endl;break;}3、显示功能,直接调用成员函数output()即可实现。