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

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

复制代码
#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;

}


相关推荐
那个村的李富贵1 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿1 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐1 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia12 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了2 小时前
数据结构之树(Java实现)
java·算法
算法备案代理2 小时前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.2 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
野犬寒鸦4 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总4 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法
rainbow68894 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法