c语言带头双链表的基础操作

1. 创建一个双链表结点

typedef int ltdatatype;

typedef struct listnode

{

int data;

struct listnode* prev;//前驱节点

struct listnode* next;//后驱结点

}ltnode;

2.创建一个新结点的函数

ltnode* ltbuynode(int x)//x是数据域

{

ltnode* newnode = (ltnode*)malloc(sizeof(ltnode));

if (newnode = NULL)

{

perror("malloc fail");

exit(1);

}

newnode->data = x;

newnode->next = NULL;

newnode->prev = NULL;

return newnode;

}

3.双链表结点的初始化

ltnode* ltinit()

{

ltnode* phead = ltbuynode(-1);

return phead;

}

4.双链表的打印

void ltprint(ltnode* phead)

{

ltnode* pcur = phead;
//用遍历链表的方式打印

assert(phead);

ltnode* pcur = phead->next;//创建指针变量pcur指向头结点

while (pcur != phead)

{

printf("%d->", pcur->data);

pcur = pcur->next;

}

printf("\n");

}

5.双链表的尾插

void ltpushback(ltnode* phead, ltdatatype x)

{

ltnode* newnode = ltbuynode(x);

//phead phead->prev newnode

newnode->next = phead;//

newnode->prev = phead->prev;

phead->prev->next = newnode;

phead->prev = newnode;

}

6.双链表的头插

void ltpushfront(ltnode* phead, ltdatatype x)

{

assert(phead);

ltnode* newnode = lbuynode(x);

//结点的连结

newnode->next = phead->next;

newnode->prev = phead;

phead->next->prev = newnode;

phead->next = newnode;

}

7.双链表的尾删

void ltpopback(ltnode* phead)

{

assert(phead);
//链表不能为空(不能只有头结点)

ltnode* del = phead->prev;

ltnode* prev = del->prev;

prev->next = phead;

phead->prev = prev;

free(del);

del = NULL;

}

8. 双链表的头删

//头删,不是删除头结点

void ltpopfront(ltnode* phead)

{

assert(phead);

assert(phead->next!=phead);

ltnode* del = phead->next;

ltnode* next = del->next;

next->prev = phead;

phead->next = next;

free(del);

del = NULL;

}

9.双链表的结点查找

//结点查找

ltnode* ltfind(ltnode* phead, ltdatatype x)

{

assert(phead);

ltnode* pcur = phead->next;//遍历循环双链表的同时又不让它成为死循环,所以应该将pcur指向第一节点

while (pcur != phead)//所以只要遍历到头结点,那么就停止遍历

{

if (pcur->data == x)//如果找到了

{

return pcur;

}

pcur = pcur->next;

}

return NULL;

}

10.双链表的指定节点之后插入数据

//指定位置pos之后插入数据

ltnode* ltfind(ltnode* pos, ltdatatype x)

{

assert(pos);

ltnode* newnode = ltbuynode(x);

newnode->next = pos->next;

newnode->prev = pos;

pos->next->prev = newnode;

pos->next = newnode;

}

11.删除指定结点

//删除pos位置的数据

void lterase(ltnode* pos)

{

assert(pos);

pos->next->prev = pos->prev;

pos->prev->next = pos->next;

free(pos);

pos->next;

}

12.双链表的销毁

void ltdestroy(ltnode* phead)

{

assert(phead);

ltnode* pcur = phead->next;

while (pcur != phead)

{

free(pcur);//每遍历一次就删除一次

pcur = pcur->next;

}

free(phead);

phead = NULL;//因为是一级指针,所以这里phead为空以后实参的一级指针仍然没空,
//所以如果实参时plist,那么经过此函数后仍要手动置空plist=NULL;

}

相关推荐
会的全对٩(ˊᗜˋ*)و3 分钟前
【数据结构】栈
数据结构·经验分享·
醇醛酸醚酮酯4 分钟前
std::promise和std::future的使用示例——单线程多链接、多线程单链接
网络·c++·算法
2301_1472583694 分钟前
7月1日作业
java·前端·算法
爱思德学术43 分钟前
中国计算机学会(CCF)推荐学术会议-B(交叉/综合/新兴):BIBM 2025
算法
冰糖猕猴桃1 小时前
【Python】进阶 - 数据结构与算法
开发语言·数据结构·python·算法·时间复杂度、空间复杂度·树、二叉树·堆、图
lifallen1 小时前
Paimon vs. HBase:全链路开销对比
java·大数据·数据结构·数据库·算法·flink·hbase
liujing102329292 小时前
Day04_刷题niuke20250703
java·开发语言·算法
2401_881244403 小时前
Treap树
数据结构·算法
乌萨奇也要立志学C++3 小时前
二叉树OJ题(单值树、相同树、找子树、构建和遍历)
数据结构·算法
网安INF3 小时前
深度学习中的逻辑回归:从原理到Python实现
人工智能·python·深度学习·算法·逻辑回归