线性表的表示与实现问题

线性表的表示与实现问题

1、线性表的背景

在计算机领域中,线性表是最常见的一种抽象数据类型。线性表可持有相同类型的数据元素(可以是相同的元素也是不同的元素),其中的每个数据元素都有一个唯一的位序号(≥0)与其相对应,因此,线性表中的数据元素按位序号排成了一个线性的序列,如图1所示。
图1 线性表的概念结构图
图1 线性表的概念结构图

从图中可以准确了解到,线性表的位序号只能在一个方向上增长或减少。线性表最大的特点在于,可通过位序号任意访问线性表中的数据元素,即增(add)、删(remove)、修(set)、查(get)等操作都需通过位序号。

2、线性表的抽象数据类型定义

将线性表考虑为一种抽象数据类型,其定义如下:
ADT list { //采用动态存储} ADT stack
数据元素集: {ai| ai ∈ element_set, 0≤i<N }
数据关系集: {<ai-1,ai>, 1≤i<N}
基本操作集:10个

    init();                /* 在内存堆中构造一个空线性表 */
    free(list);           /* 在内存堆中释放线性表list */
    clear(list);          /* 把线性表list中的数据元素清空 */
    isempty(list);        /* 判断线性表list是否为空,为空返回1,不为空返回0 */ 
    count(list);          /* 返回线性表list中的数据元素个数 */ 
    add(list,index,e);   /* 把元素e插入到线性表list的index位置 */ 
    set(list,index,e);   /* 把元素e放到线性表list的index位置,原有元素被覆盖 */
	get(list,index);     /* 返回线性表list在index位置的元素 */
    remove(list,index); /* 移除线性表list在index位置的元素,并将该元素返回*/ 
    lookup(list, e);    /* 在线性表list中查找是否存在元素e,存在返回1,否则返回0 */

3、线性表的存储结构设计

现设计有如下的三种存储结构(实际上只有两种:顺序栈与链式栈),其中的数据元素约定为int类型。

结构A:顺序表

顺序表的存储结构

结构B:不带头结点的单向链表

不带头结点的单向链表结构

结构C:带头结点的单向链表

带头结点的单向链表结构

顺序表的存储结构代码实现:
//download.csdn.net/download/Dumbking/12135872
不带头结点的单向链表结构:
//download.csdn.net/download/Dumbking/12135839

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dumbking

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值