线性表的顺序储存及基本操作

#include<stdio.h>
#include<stdlib.h>
#define INIT_SIZE 10    // 线性表初始容量
#define INCREMENT_SIZE 5 // 当线性表容量不够时,增加元素之前,线性表增长量
#define OVERFLOW -5 // 内存分配失败后的退出代号

typedef struct {
    int *data;  // 线性顺序表的基地址(首地址)ַ
    int length; // 当前线性表元素个数
    int capacity; //当前线性表的容量
} SequenceList;

/*
 * 初始化线性表分配内存空间以及相关参数设定
 */
void init_list(SequenceList *slist)
{

    slist->data = (int *)malloc(INIT_SIZE*sizeof(int));
    if(!slist->data) exit(OVERFLOW); // 如果分配内存失败则退出程序
    slist->length = 0;  //初始化当前元素个数为0
    slist->capacity = INIT_SIZE; // 初始化当前线性表容量为INIT_SIZE
}

/*
 * 插入操作
 */
void Insert(SequenceList *slist, int element, int index)
{

    // 插入之前判断线性表的容量是否够大,如果不够,按照INCREMENT_SIZE扩充容量
    // 重新申请内存空间
    if(index >= slist->capacity)
    {
        slist->data = (int *)realloc(slist->data,
                                  (slist->capacity + INCREMENT_SIZE)*sizeof(int));
        if(!slist->data) exit(OVERFLOW);
        slist->capacity += INCREMENT_SIZE;
    }

    for(int i=slist->length-1; i > index ; i--)
        *(slist->data + i + 1) = *(slist->data + i);

    *(slist->data + index) = element;
    slist->length++;

}

/*
 * 索引操作
 */
int getElement(SequenceList *slist, int index)
{
    return *(slist->data + index);
}

/*
 * 更新操作
 */
void updateElement(SequenceList *slist, int index, int newValue)
{
    *(slist->data + index) = newValue;
}

/*
 * 删除操作
 */
int deleteElement(SequenceList *slist, int index)
{
    int result = *(slist->data + index);
    for(int i=index; i < slist->length; i++)
        *(slist->data + i) = *(slist->data + i + 1);
    slist->length--;
    return result;
}

/*
 * 合并操作
 */
SequenceList mergeList(SequenceList slist1, SequenceList slist2)
{

    SequenceList newList;
    init_list(&newList);

    int p = 0;
    int q = 0;
    int r = 0;

    while(p<slist1.length && q<slist2.length){
        int a = *(slist1.data+p);
        int b = *(slist2.data+q);

        printf("compare a = %d, b = %d\n", a, b);

        if (a <= b){
            Insert(&newList, a, r);
            p++;
        }else {
            Insert(&newList, b, r);
            q++;
        }
        r++;

    }

    while(p < slist1.length) {
       Insert(&newList,  *(slist1.data + p), r);
       r++;
       p++;
    }

    while(q < slist2.length) {
       Insert(&newList, *(slist2.data + q), r);
       r++;
       q++;
    }

    return newList;

}

/*
 * 打印线性顺序表的所有信息
 */
void print_slist_info(SequenceList slist)
{

    printf("sequence list\ncapacity is %d\nlength is %d\n", slist.capacity, slist.length);
    for(int i=0; i < slist.length; i++)
        printf("%d ", *(slist.data + i));
}


int main()
{
    SequenceList sequence_list;
    init_list(&sequence_list);
    return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值