单链表接口函数的实现(增删查改)

一、单链表的实现形式以及接口函数的声明

复制代码
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
typedef int DataType ;

typedef struct SListNode
{
	DataType data;
	struct SListNode* next;
}SLTNODE;
void SLTPrint(SLTNODE* phead);//打印链表
SLTNODE* SLTBuyNode(DataType x);//创建节点
void SLTPushBack(SLTNODE** phead, DataType x);//尾插
void SLTPushFront(SLTNODE** phead, DataType x);//头插
void SLTPopBack(SLTNODE** phead);//尾删
void SLTPopFront(SLTNODE** phead);//头删
SLTNODE* SLTFind(SLTNODE* phead, DataType x);//查找
void SLTInsert(SLTNODE** phead, SLTNODE* pos, DataType x);//待定位置之前的插入
void SLTInsertAfter( SLTNODE* pos, DataType x);//待定位置之后的插入
void SLTErase(SLTNODE** phead, SLTNODE* pos);//删除待定节点
void SLTEraseAfter( SLTNODE* pos);//删除待定节点之后的节点
void SLTDestroy(SLTNODE** phead);//销毁链表

二、接口函数的实现

1.打印链表

代码如下(示例):

c 复制代码
void SLTPrint(SLTNODE* phead)//打印链表
{
    SLTNODE* cur = phead;
    while (cur)
    {

        printf("%d->", cur->data);
        cur = cur->next;
    }
    puts("NULL");
}

2.创建节点

代码如下(示例):

c 复制代码
SLTNODE* SLTBuyNode(DataType x)//创建节点
{
    SLTNODE* newnode = (SLTNODE*)malloc(sizeof(SLTNODE));
    assert(newnode);
    newnode->data = x;
    newnode->next = NULL;
    return newnode;
}

3.尾插

代码如下(示例):

void SLTPushBack(SLTNODE** phead, DataType x)//尾插

{

assert(phead);

SLTNODE* newnode = SLTBuyNode(x);

if (*phead == NULL)

{

*phead = newnode;

}

else

{

SLTNODE* tail = *phead;

while (tail->next)

{

tail = tail->next;

}

tail->next = newnode;

}

}

4.头插

代码示例:

void SLTPushFront(SLTNODE** phead, DataType x)//头插

{

assert(phead);

SLTNODE* newnode = SLTBuyNode(x);

newnode->next = *phead;

*phead = newnode;

}

5.尾删

代码示例:

void SLTPopBack(SLTNODE** phead)//尾删

{

assert(phead && *phead);

if ((*phead)->next == NULL)

{

free(*phead);

*phead = NULL;

}

else

{

SLTNODE* prev = NULL;

SLTNODE* tail = *phead;

while (tail->next)

{

prev = tail;

tail = tail->next;

}

free(tail);

prev->next = NULL;

}

}

6.头删

代码示例:

void SLTPopFront(SLTNODE** phead)//头删

{

assert(phead && *phead);

SLTNODE* next = (*phead)->next;

free(*phead);

*phead = next;

}

7.查找

代码示例:

SLTNODE* SLTFind(SLTNODE* phead, DataType x)//查找

{

assert(phead);

SLTNODE* cur = phead;

while (cur)

{

if (cur->data == x)

{

return cur;

}

cur = cur->next;

}

return NULL;

}

8.指定位置之前的插入

代码如下:

void SLTInsert(SLTNODE** phead, SLTNODE* pos, DataType x)//待定位置之前的插入

{

assert(phead && *phead);

assert(pos);

if (pos == *phead)

{

SLTPushFront(phead, x);//头插

}

else

{

SLTNODE* newnode = SLTBuyNode(x);

SLTNODE* prev = *phead;

while (prev->next!=pos)

{

prev = prev->next;

}

newnode->next = prev->next;

prev -> next = newnode;

}

}

9.指定位置之后的插入

void SLTInsertAfter( SLTNODE* pos, DataType x)//待定位置之后的插入

{

assert(pos);

SLTNODE* newnode = SLTBuyNode(x);

newnode->next = pos->next;

pos->next = newnode;

}

10.删除待定位置的节点

代码示例:

void SLTErase(SLTNODE** phead, SLTNODE* pos)//删除待定节点

{

assert(phead && *phead);

assert(pos);

if (pos == *phead)

{

SLTPopFront(phead);

}

else

{

SLTNODE* prev = *phead;

while (prev->next != pos)

{

prev = prev->next;

}

prev->next = pos->next;

free(pos);

}

}

11.销毁链表

代码示例:

void SLTDestroy(SLTNODE** phead)//销毁链表

{

assert(*phead && phead);

SLTNODE* cur = *phead;

while (cur)

{

SLTNODE* next = cur->next;

free(cur);

cur = next;

}

*phead = NULL;

}


相关推荐
颜酱7 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone773912 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub15 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub15 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙15 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub19 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库19 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语071619 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法