一、定义单链表结构
- 代码:
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