C语言实现链表之单向链表(十)删除任意结点

C语言实现链表之单向链表(十)删除任意结点


    上一篇文章给出了插入任意结点的函数,本篇文章将给出删除任意结点的函数。

/*============================================================================== 
*   操作  :删除任意结点
*   操作前:ppHeadNode为链表的头指针的二级指针,name为链表中的数据元素关键字
*   操作后:结点被删除,操作成功返回TRUE,操作失败返回FALSE
==============================================================================*/
C_Bool DeletOtherNode(MyListNode** ppHeadNode, char* name)
{
    MyListNode* pListNodeTmp1 = (*ppHeadNode);
    MyListNode* pListNodeTmp2 = NULL;
    int iCount = 0;

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

    // 找到要删除结点的位置
    while(pListNodeTmp1 != NULL)
    {
        iCount++;
        if(!(strcmp(name, pListNodeTmp1->sNodeData.cName)))
        {
            break;
        }
        pListNodeTmp2 = pListNodeTmp1;      // 保存pListNodeTmp1的前一结点
        pListNodeTmp1 = pListNodeTmp1->pNextNodeAddr;
    }

    // 没有在链表中找到关键字标志的结点
    if(pListNodeTmp1 == NULL)
    {
        fprintf(stderr, "Sorry, can't find the node.\n");
        return FALSE;
    }
    else if(iCount == 1)
    {
        // 删除的是头结点
        DeletFirstNode(ppHeadNode);
        return TRUE;
    }
    else if(pListNodeTmp1->pNextNodeAddr == NULL)
    {
        // 删除的是尾结点
        DeletTailNode(ppHeadNode);
        return TRUE;
    }

    // 执行删除和重新链接的操作
    pListNodeTmp2->pNextNodeAddr = pListNodeTmp1->pNextNodeAddr;
    free(pListNodeTmp1);
    pListNodeTmp1 = NULL;

    return TRUE;
}

    这个函数的复杂度是仅次于上一个函数,注意其中的计数判断,计数器主要是用来判断所删除的结点到底是头结点还是尾结点或者是其他结点。

(1)该函数通过调用DeletFirstNode()、DeletTailNode()实现了头结点或者尾结点的删除,其他结点的删除采取的是正常处理;

(2)该函数采用了我们自己定义的布尔变量;

(3)该函数依旧进行了错误判断和错误处理。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值