首页 > 其他分享 >DS-单链表:定位第pos个结点的前驱

DS-单链表:定位第pos个结点的前驱

时间:2023-02-16 01:23:11浏览次数:41  
标签:结点 myLNode pos 链表 phead NULL DS

一、定义单链表结构

  • 代码:


typedef int linkType;	       ///< 定义链表结点数据域数据类型

/// @brief  链表结点定义
typedef struct t_linkNode
{
    struct t_linkNode* pnext;  ///< 结点指针域
    linkType data;             ///< 结点数据域
}myLNode;

/// @brief 链表结构定义
typedef struct t_linkList
{
    myLNode* phead;   //< 链表头结点指针
}myLinkList;

二、定位第pos个结点的前驱

1、思路

  • 代码:


/// @brief 定位链表第pos个位序结点的前驱
/// @param plist :链表指针
/// @param pos :位序,取值范围是[1,size]
/// @return 返回第pos个结点的前驱
myLNode* xxx_locatePre(myLinkList* plist, int pos)
{
    if (plist == NULL)
    {
        return NULL;
    }
    return xxx_locatePre_(plist->phead, pos);
}
myLNode* xxx_locatePre_(myLNode* phead, int pos)
{
    if (phead == NULL || phead->pnext == NULL)
    {
        return NULL;
    }
    myLNode* p = phead->pnext;
    myLNode* pre = phead;       ///< 借助pre来记录p结点前驱
    int i = 1;
    while (p != NULL && i < pos)
    {
        pre = p;
        p = p->pnext;
        ++i;
    }
    /// 未找到的情况
    /// 1、pos太小,pos=0时,i>pos恒成立:头结点是没有前驱的
    /// 2、pos太大,pos=size+1,i<pos恒成立,继续while,使得p=NULL
    /// 3、pos刚好,pos=1时,刚好找到
    ///
    if (p == NULL || i > pos)
    {
        pre = NULL;
    }
    return pre;
}

标签:结点,myLNode,pos,链表,phead,NULL,DS
From: https://www.cnblogs.com/kxwslmsps/p/17125264.html

相关文章

  • DS-单链表:判定单链表是否为空表
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:定位单链表第pos个结点
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:查找元素值为x的结点的前驱结点
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:查找单链表中第一个元素值为x的结点
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:创建一个新结点
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:定位单链表尾结点
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:单链表结构定义
    一、公共头文件代码如下:#ifndef__MYHEAD_H__#define__MYHEAD_H__/*******************************************************************@file:myhead.h*@......
  • DS-单链表:初始化单链表
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_linkNode*......
  • DS-单链表:清空单链表
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......
  • DS-单链表:销毁单链表
    一、定义单链表结构代码:typedefintlinkType; ///<定义链表结点数据域数据类型///@brief链表结点定义typedefstructt_linkNode{structt_lin......