这篇博客完成单链表的最后部分,包括单链表的查找,任意位置插入删除数据,以及动态内存的释放。
1. 单链表的查找
单链表的结构如下图所示,我们查找数据只需将链表遍历一遍是否有需要查找的数据,同时也要考虑链表初始为空的情况。
SLTNode* STFind(SLTNode* phead, SLTDataType x)
2. 在 pos 位置 之前/之后 插入数据
在此处我们考虑两种情况,一是 pos 位置处即为头结点位置,以及 pos 位置是中间结点的位置,如下图所示:
第一种情况我们只需调用之前的头部插入数据的函数即可 ,第二种情况我们需要遍历到 pos 前一个位置,在此处插入结点即可。
void SLInsert(SLTNode** pphead, SLTNode* pos, SLTDataType x)
SLPushFront(pphead, x); //调用头插函数
while (prev->next != pos)
SLTNode* newnode = BuyLTNode(x);
而则在 pos 位置之后插入数据则十分简单,直接在后面插入结点即可。代码如下:
void SLInsertAfter(SLTNode* pos, SLTDataType x)
SLTNode* newnode = BuyLTNode(x);
newnode->next = pos->next;
3. 在 pos 位置/之后删除数据
在 pos 位置删除数据数据同样判断两种情况,当 pos 位置是头结点时,调用头删函数即可,否则遍历到 pos 结点位置,然后跳过 pos 结点,指向下一个结点的地址,再 free(pos) 即可。
void SLErase(SLTNode** pphead, SLTNode* pos)
SLPopFront(pphead);//头部删除数据
while (prev->next != pos)
删除 pos 位置之后的数据则十分简单,代码如下:
void SLEraseAfter(SLTNode* pos)
SLTNode* next = pos->next;
4. 内存释放
free 每一个结点,phead 置空即可 ,代码如下:
void SLDestory(SLTNode** pphead)
SLTNode* next = cur->next;
5. 结果
SLTNode* pos = STFind(plist,3);//找 data = 3 的结点
SLInsert(&plist, pos, 100);//在 3 前插入100
SLInsertAfter(pos, 200);//在 3 后插入200
SLEraseAfter(pos);//删除 3 后面的 200
SLErase(&plist,pos);//删除 3