数据结构学习笔记——顺序数组2

接着昨天的数组操作,数组初始化好了,我们要往里面添加元素,可以在尾部追加或者插入,刚开始数组为空,所以先追加

int AppendList(SqList* pArr, ElemType val)
{
    if (Is_Full(pArr))  //判断数组是否已经满了
    {
        printf("数组已满!\n");
        return 0;
    }
    pArr->elem[pArr->listsize] = val;//将相应的数据赋给数组
    pArr->listsize++;//当前数组可用元素加一
    return 1;
}

int Is_Full(SqList* pArr)
{
    if (pArr->listsize == pArr->length)
        return 1;
    else
        return 0;
}

我们可以写进程序验证一下,接下来是插入元素

int InsertList(SqList* pArr, int pos, ElemType val)
{
    if (Is_Full(pArr))
    {
        printf("  数组已满!\n");
        return 0;
    }
    if (pos<0 || pos>(pArr->listsize+1))
    {
        printf("插入范围错误或数组越界!\n");
        return 0;
    }
    for (int i = pArr->listsize - 1; i >= pos - 1; i--)//将数组元素一个一个往后移
        pArr->elem[i + 1] = pArr->elem[i];
    pArr->elem[pos - 1] = val;//将值插入位置
    pArr->listsize++;
    return 1;
}
删除元素的算法基本类似,就是得提前定义一个变量接受删除的值,顺序表就这样差不多了,接下来写个小程序使用这个!

转载于:https://www.cnblogs.com/acgpiano/p/4029508.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值