静态分配的顺序表

顺序表的存储可分为动态存储和静态存储,动态和静态的区别是存储地址是动态申请还是直接定义的数组,其存储地址都是连续的,C中借助数组来实现。

其主要特性是具有很好的随机访问特性和存储密度高。

其插入,删除和查找的平均时间复杂度均为O(n)。


下面是一个简单的实现,Linux下gcc可以直接编译通过,测试。

#include <stdio.h>
#include <string.h>

#define MAXSIZE 50

//元素类型定义
typedef int ElemType;


typedef struct{
    ElemType data[MAXSIZE];
    int length;
}SeqList;

//向顺序表中插入元素,pos为数组下表的插入位置
int ListInsert(SeqList *L, int pos, ElemType val)
{
    if((L->length >= MAXSIZE)||(pos < 0) || (pos >= MAXSIZE))
        return -1;

    int i;
    for(i = L->length; i > pos; i++){
            L->data[i] = L->data[i-1];
    }
    
    L->data[pos] = val;
    L->length++;

    return 0;
}

//删除顺序表中下标位置为pos的元素
int ListDelete(SeqList *L, int pos)
{
    if((L->length == 0) || (pos > MAXSIZE))
        return -1;

    int i;
    for(i = pos; i < L->length-1; i++){
        L->data[i] = L->data[i+1];
    }

    L->length --;

    return 0;
}

//查找顺序表中值为val的元素,返回该元素的下表位置
int ListSearch(SeqList *L, ElemType val)
{
    if(L->length == 0)
        return -1;

    int i;
    for(i = 0; i < L->length; i++){
        if(L->data[i] == val)
            return i;
    }

    return -1;
}

//测试主函数
int main()
{
    int i = 0;
    SeqList L;
    memset(&L, 0 ,sizeof(L));
    while(i < MAXSIZE){
        ListInsert(&L, i, i);
        i++;
    }

    ListDelete(&L, 19);
    for(i = 0; i < L.length; i++)
        printf("%d ", L.data[i]);

    printf("\n");
    printf("13 is at pos: %d\n", ListSearch(&L, 13));
    return 0;    
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值