《大话数据结构》读后总结(九)

线性表

顺序存储结构的插入与删除

获得元素操作
#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 < 1 || 
        i > L.length)
        return ERROR;
    *e = L.data[i - 1];
    return OK;
}
复制代码
插入操作
/* 初始条件:顺序线性表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;
    /* 当i不在范围内时 */
    if (i < 1 || i >L->length + 1)                  
        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;                             
    L->length++;
    return OK;
}
复制代码
删除操作
/* 初始条件:顺序线性表L已存在,1≤i≤
   ListLength(L) */
/* 操作结果:删除L的第i个数据元素,并用e返回
   其值,L的长度减1 */
Status ListDelete(SqList *L, int i, ElemType *e)
{
    int k;
    /* 线性表为空 */
    if (L->length == 0)                    
           return ERROR;
    /* 删除位置不正确 */
    if (i < 1 || i > L->length)            
        return ERROR;
    *e = L->data[i - 1];
    /* 如果删除不是最后位置 */
    if (i < L->length)                     
    {
        /* 将删除位置后继元素前移 */
        for (k = i; k < L->length; k++)    
            L->data[k - 1] = L->data[k];
    }
    L->length--;
    return OK;
}
复制代码

线性表的顺序存储结构,在存、读数据时,不管是哪个位置,时间复杂度都是O(1);而插入或删除时,时间复杂度都是O(n)。

线性表顺序存储结构的优缺点

欢迎扫描下方二维码,持续关注:

互联网工程师(id:phpstcn),我们一起学习,一起进步

转载于:https://juejin.im/post/5ca5d0e351882544097e23e8

你可能感兴趣的:(《大话数据结构》读后总结(九))