【数据结构和算法】Day 8

线性表有两种物理存储结构:顺序存储结构和链式存储结构。


顺序存储结构:指的是用一段地址连续的存储单元依次存储线性表的数据元素,其结构代码如下。

#define MAXSIZE 20
typedef int Elemtype;
typedef struct
{
    ElemType data[MAXSIZE];
    int length; //线性表当前长度
}SqList

可见,顺序存储结构封装需要三个属性:

a.存储空间的起始位置,数组data的存储位置就是线性表存储空间的存储位置。

b.线性表的最大存储容量:数组的长度MaxSize。

c.线性表的当前长度:length


线性表和数组不同,其起始是从1开始的,而不像数组,是从0开始的。


用c来表示ElemType占用的存储单元数(字节),那么线性表中第i+1个数据元素和第i个数据元素存储位置的关系是(LOC表示获取存取位置的函数):LOC(ai+1) = LOC(ai) + c。


所以对于第i个数据元素ai的存储位置可以由a1推算的出:LOC(ai) = LOC(a1) + (i-1)*c。


随机存取结构:存储单元的内容可按需随意取出或存入,且存取的速度与存储单元的位置无关,即存取时间性能为O(1)。


实现GetElem的具体代码

#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0

typedef int Status;

//Status是函数的类型,其值是函数结果转台代码,如OK等。
//初始条件:顺序线性表L已存在,1 <= i <= ListLength(L)
//操作结果:用e返回L中第i个数据元素的值。

Status GetElem(SqList L, int i, ElemType *e)
{
    if( L.length ==0 || i<i || i>L.length )
    {
        return ERROR;
    }
    *e = L.data[i-1];
    return OK;
}

注意返回值类型Status,是一个整形,约定返回1代表OK,返回0代表ERROR。


实现ListInsert操作的具体代码

/*初始条件:顺序线性表L已存在,1 <= i <= Listlength(L)。 */
/*操作结果:在L中第i个位置之前插入新的数据元素e,L长度+1。 */

Status ListInsert(SqList *L, int i, ElemType e)
{
    int k;

    if( L->length == MAXSIZE )    //顺序线性表已满
    {
        return ERROR;
    }
    if( i<1 i="">L->length+1 )    //当i不在范围内时
    {
        return ERROR;
    }
    if( i <= L->length )    //若插入数据位置不在表尾
    {
        /*将要插入位置后的数据元素向后移动一位*/
        for( k=L->length-1; k >= i-1; k-- )
        {
            L->data[k+1] = L->data[k];
        }
    }
    
    L->data[i-1] = e;   //将i新元素插入
    L->length++;

    return OK;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值