D_S 线性表的顺序表示和实现

时间:2021-07-31 09:02:55

线性表的顺序表示又称为顺序存储结构或顺序映像

顺序存储定义:把逻辑上相邻的数据元素存储在物理上相邻的存储单元中的存储结构,简言之,逻辑上相邻,物理上也相邻

顺序存储方法:用一组地址连续的存储单元依次存储线性表的元素,可通过数组V[n]来实现

顺序表的类型定义:

#define  MAXSIZE 100     //最大长度

typedef  struct {

ElemType  *elem;     //指向数据元素的基地址

int  length;          //线性表的当前长度

}SqList;

初始化线性表L (参数用引用)

Status InitList_Sq(SqList &L){    //构造一个空的顺序表L

L.elem=new ElemType[MAXSIZE];   //为顺序表分配空间

if(!L.elem) exit(OVERFLOW);       //存储分配失败

L.length=0;    //空表长度为0

return OK;

}

初始化线性表L (参数用指针)

Status InitList_Sq(SqList *L){    //构造一个空的顺序表L

L-> elem=new ElemType[MAXSIZE];   //为顺序表分配空间

if(! L-> elem) exit(OVERFLOW);       //存储分配失败

L-> length=0;                  //空表长度为0

return OK;

}

销毁线性表L

void DestroyList(SqList &L){

if (L.elem) delete[]L.elem;    //释放存储空间

}

清空线性表L

void ClearList(SqList &L) {

L.length=0;                //将线性表的长度置为0

}

求线性表L的长度

int GetLength(SqList L){

return (L.length);

}

判断线性表L是否为空

int IsEmpty(SqList L){

if (L.length==0) return 1;

else return 0;

}

获取线性表L中的某个数据元素的内容

//根据指定位置,获取相应位置数据元素的内容

int GetElem(SqList L,int i,ElemType &e){

if (i<1||i>L.length) return ERROR;

//判断i值是否合理,若不合理,返回ERROR

e=L.elem[i-1];   //第i-1的单元存储着第i个数据

return OK;

}

在线性表L中查找值为e的数据元素

int LocateELem(SqList L,ElemType e)

{

for (i=0;i< L.length;i++)

if (L.elem[i]==e) return i+1;

return 0;

}

在线性表L中第i个数据元素之前插入数据元素e

Status ListInsert_Sq(SqList &L,int i ,ElemType e){

if(i<1 || i>L.length+1) return ERROR;           //i值不合法

if(L.length==MAXSIZE) return ERROR;    //当前存储空间已满

for(j=L.length-1;j>=i-1;j--)

L.elem[j+1]=L.elem[j];    //插入位置及之后的元素后移

L.elem[i-1]=e;                     //将新元素e放入第i个位置

++L.length;         //表长增1

return OK;

}

将线性表L中第i个数据元素删除

Status ListDelete_Sq(SqList &L,int i,ElemType &e){

if((i<1)||(i>L.length)) return ERROR;  //i值不合法

e=L.elem[i-1];                              //将欲删除的元素保留在e中

for (j=i;j<=L.length-1;j++)

    L.elem[j-1]=L.elem[j];       //被删除元素之后的元素前移

--L.length;                       //表长减1

return OK;

}

D_S 线性表的顺序表示和实现的更多相关文章

  1. 数据结构算法C语言实现(一)---2&period;2线性表的顺序表示和实现

    注意: 虽然是用C语言实现,但是考虑到使用了一个C++的特性----引用以简化代码,所以所有的代码均以cpp作为后缀,用g++编译(以后不做说明). g++版本: 一.简述 本节主要讲述线性表的顺序实 ...

  2. C&num;线性表之顺序表

    线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...

  3. javascript实现数据结构:线性表--简单示例及线性表的顺序表示和实现

    线性表(linear list)是最常用且最简单的一种数据结构.一个线性表是n个数据元素的有限序列.在稍复杂的线性表中,一个数据元素可以由若干个数据项(item)组成. 其中: 数据元素的个数n定义为 ...

  4. c&sol;c&plus;&plus; 线性表之顺序表

    线性表之顺序表 存储在连续的内存空间,和数组一样. 下面的代码,最开始定义了一个能存8个元素的顺序表,当超过8个元素的时候,会再追加开辟空间(函数:reInit). 实现了以下功能: 函数 功能描述 ...

  5. 已知长度为n的线性表采用顺序结构,写一算法删除该线性表中所有值为item的元素

    /** * @author:(LiberHome) * @date:Created in 2019/2/27 23:34 * @description: * @version:$ */ /*已知长度为 ...

  6. 线性表之顺序栈C&plus;&plus;实现

    线性表之顺序栈 栈是限定仅在表尾(栈顶)进行插入删除操作的线性表,FILO:先进后出 一.顺序栈的头文件:SeqStack.h //顺序栈头文件 #include<iostream> us ...

  7. 线性表之顺序表C&plus;&plus;实现

    线性表之顺序表 一.头文件:SeqList.h //顺序线性表的头文件 #include<iostream> ; //定义顺序表SeqList的模板类 template<class ...

  8. 线性表中顺序表的的理解和实现&lpar;java&rpar;

    线性表的顺序表示指的是用一组地址连续的存储单元以此存储线性表的数据元素,这种表示也称作线性表的顺序存储结构或顺序映像.通常,称这种存储结构的线性表为顺序表.特点是:逻辑上相邻的数据元素,其物理次序上也 ...

  9. &lbrack;C&plus;&plus;&rsqb;数据结构:线性表之顺序表

    1 顺序表 ADT + Status InitList(SeqList &L) 初始化顺序表 + void printList(SeqList L) 遍历顺序表 + int ListLengt ...

随机推荐

  1. java&period;lang&period;ClassNotFoundException&colon; org&period;springframework&period;web&period;context&period;ContextLoaderListener

    参考: http://www.cnblogs.com/sunxucool/archive/2013/06/07/3124380.html   ---------------------------&g ...

  2. 使用jasmine来对js进行单元测试

    互联网的快速发展,给web开发人员带来了前所未有的挑战.对于前端开发,前端开发er所需要编写的js早已不是那些寥寥几行的视觉效果代码.代码量的大增,多人协同,人员素质悬殊不齐,这都需要一个标准,来对代 ...

  3. JSTL标签用法 详解

    在JSP的开发中,迭代是经常要使用到的操作.例如,逐行的显示查询的结果等.在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出.现在,通过JST ...

  4. Linux环境变量&lpar;小马哥推荐&rpar;

    /etc/profile:此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. 并从/etc/profile.d目录的配置文件中搜集shell的设置. /etc/bashrc:为每一 ...

  5. redis神器

    redis是内存型数据库,数据保存在内存中,通过tcp直接存取,优势是速度快,并发高,缺点是数据类型有限,查询功能不强,一般用作缓存. redis具有持久化机制,可以定期将内存中的数据持久化到硬盘上. ...

  6. 百度云推送的Java实现

    推送现在基本APP都有,项目中要通知和消息,所以综合考虑用了百度云推送 Java实现步骤: 1. 下载 http://push.baidu.com/sdk/push_server_sdk_for_ja ...

  7. QQ互联功能

    QQ作为现在使用人数最多的几个聊天软件之一,倘若能够方便的进行沟通(在大家的机器上都安装了QQ客户端或者浏览器的前提下),在商家推广的时候也许会带来不小的利益. http://wp.qq.com/in ...

  8. Java程序i学习中各阶段的建议

    第一部分:对于尚未做过Java工作的同学,包括一些在校生以及刚准备转行Java的同学. 一.Java基础 首先去找一个Java的基础教程学一下,这里可以推荐一个地址,或者你也可以参照这个地址上去找相应 ...

  9. Error&colon;Failed to resolve&colon; com&period;android&period;support&period;constraint&colon;constraint-layout&colon;1&period;0&period;2

    可以换个maven库: allprojects { repositories { jcenter() //maven { url "https://jitpack.io" } ma ...

  10. 082 HBase的几种调优(GC策略,flush,compact,split)

    一:GC的调优 1.jvm的内存 新生代:存活时间较短,一般存储刚生成的一些对象 老年代:存活时间较长,主要存储在应用程序中生命周期较长的对象 永久代:一般存储meta和class的信息 2.GC策略 ...