首页 > 其他分享 >单链表:查找元素x的前驱结点

单链表:查找元素x的前驱结点

时间:2023-02-14 18:44:06浏览次数:40  
标签:结点 单链 myLNode 链表 phead 前驱 NULL 查找

一、单链表结构定义

typedef void(myOpFunType)(void*);	///< 定义操作函数类型
typedef int linkType;			///< 定义链表结点数据域数据类型

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

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

 

二、查找单链表中元素x所在结点的前驱结点,返回其地址

/// @brief 查找x元素第一次出现在链表时所在结点的前驱结点
/// @param plist 链表指针
/// @param x 待查找元素
/// @return 返回前驱结点地址
/// @retval 非NULL:查找成功
/// @retval 0地址值:查找失败
myLNode* xxx_findPre(myLinkList* plist, linkType x)
{
    if (plist == NULL)
    {
        return NULL;
    }
    return xxx_findPre_(plist->phead, x);
}
myLNode* xxx_findPre_( myLNode* phead, linkType x)
{
    if (phead == NULL || phead->pnext == NULL)
    {
        return NULL;
    }
    myLNode* p = phead->pnext;  ///< 记录待查x所在结点
    myLNode* pre = phead;       ///< 记录待查x所在结点的前驱结点
    while (p != NULL && p->data != x)
    {
        pre = p;
        p = p->pnext;
    }
    /// 若已经找到,则p不为空,若遍历完仍未找到,则p为空
    if (p == NULL)
    {
        pre = NULL;
    }
    return pre;
}

 

标签:结点,单链,myLNode,链表,phead,前驱,NULL,查找
From: https://www.cnblogs.com/kxwslmsps/p/17120584.html

相关文章