C语言实现链表之双向链表(七)尾结点后插入结点

C语言实现链表之双向链表(七)尾结点后插入结点


    上一篇文章给出了删除头结点的函数,本篇文章将给出在尾结点后插入结点的函数。注意双向链表中前向指针的处理,与单向链表对比学习一下。

/*============================================================================== 
*   操作  :在尾结点之后加入一个新结点
*   操作前:pHeadNode为链表的头指针,ListData为待加入的结点数据元素
*   操作后:数据元素为ListData的结点被加到尾结点后面,成功返回头结点,否则返回NULL
==============================================================================*/
MyListNode* InsertTailNode(MyListNode* pHeadNode, MyListData ListData)
{
    MyListNode* pListNodeTmp  = pHeadNode;
    MyListNode* pListNodeTmp1 = NULL;

    // 判断是否有链表输入
    if(pHeadNode == NULL)
    {
        fprintf(stderr, "There is no list.\n");
        return NULL;
    }

    // 为新增结点分配内存
    pListNodeTmp1 = MallocMemInitNode(pListNodeTmp1);
    if(pListNodeTmp1 == NULL)
    {
        fprintf(stderr, "The new node's memory allocating defeat.\n");
        return NULL;
    }
    pListNodeTmp1->sNodeData = ListData;

    // 将指针移至尾结点
    while(pListNodeTmp->pNextNodeAddr != NULL)
    {
        pListNodeTmp = pListNodeTmp->pNextNodeAddr;
    }
    pListNodeTmp ->pNextNodeAddr = pListNodeTmp1;
    pListNodeTmp1->pPrevNodeAddr = pListNodeTmp;

    return pHeadNode;
}

    强调几点:

(1)该函数依旧调用了MallocMemInitNode()函数用来分配内存,但是数据是由函数传入的;

(2)该函数依旧进行了错误判断和错误处理;

(3)记得返回头结点。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值