【C语言数据结构】之解锁双向链表(头插、头删等操作)

Hello,大家好呀! 欢迎来到【01二进制代码漫游日记】。

在C语言的浩瀚宇宙中,数据结构绝对是那颗最耀眼的恒星。今天,我们要一起解锁的,是数据结构中极其灵活、却又让不少人头疼的------双向链表

别担心,这篇内容不仅仅是枯燥的代码堆砌。我会手把手带你理清它的逻辑,从最基础的头插法 到复杂的节点删除,一步步拆解。在正式敲代码之前,我们先来认识一下今天的"作战地图",看看各个文件都扮演着什么角色......

一、文件定义及作用

1.1.4-21.c文件及作用

实现文件,作用是包含函数的具体逻辑代码

1.2.List.h文件及作用

头文件,作用是定义结构体 和所有函数的接口。

1.3.test.h文件及作用

测试文件,作用是程序的入口,演示如何使用上述所有功能。

二、头插及其实现方式

2.1.List.h(头文件)

完整代码如下:

#include<stdlib.h>

#include<assert.h>

typedef int LTDataType;

typedef struct LTNode {

LTDataType data;

struct LTNode* prev;

struct LTNode* next;

}LTNode;

//申请节点

LTNode* LTBuyNode(LTDataType x);

void LTInit(LTNode** pphead);

void LTPushBack(LTNode* phead, LTDataType x);

void LTPrint(LTNode* phead);
void LTPushFront(LTNode* phead, LTDataType x);

2.2.4-21.c(实现文件)

完整代码如下:

void LTPushFront(LTNode* phead, LTDataType x) {

LTNode* newnode = LTBuyNode(x);

assert(phead);

newnode->prev = phead;

newnode->next = phead->next;

phead->next->prev = newnode;

phead->next = newnode;

}

2.3.test.c(实现文件)

完整代码如下:

LTPushFront(plist, 5);

LTPrint(plist);

LTPushFront(plist, 6);

LTPrint(plist);

LTPushFront(plist, 7);

LTPrint(plist);

LTPushFront(plist, 8);

LTPrint(plist);

测试结果如下:

三、尾删及其实现方式

3.1.List.h(头文件)

完整代码如下:

#pragma once

#include<stdio.h>

#include<stdlib.h>

#include<assert.h>

typedef int LTDataType;

typedef struct LTNode {

LTDataType data;

struct LTNode* prev;

struct LTNode* next;

}LTNode;

//申请节点

LTNode* LTBuyNode(LTDataType x);

void LTInit(LTNode** pphead);

void LTPushBack(LTNode* phead, LTDataType x);

void LTPrint(LTNode* phead);

void LTPushFront(LTNode* phead, LTDataType x);
void LTPopBack(LTNode* phead);

3.2.4-21.c(实现文件)

完整代码如下:

//尾删

void LTPopBack(LTNode* phead) {

assert(phead && phead->next != NULL);

LTNode*del = phead->prev;

del->prev->next = phead;

phead->prev = del->prev;

free(del);

del = NULL;

}

3.3.test.c(实现文件)

完整代码如下:

LTPopBack(plist);

LTPrint(plist);

LTPopBack(plist);

LTPrint(plist);

LTPopBack(plist);

LTPrint(plist);

测试结果如下:

四、头删及其实现方式

4.1.List.h(头文件)

完整代码如下:

#pragma once

#include<stdio.h>

#include<stdlib.h>

#include<assert.h>

typedef int LTDataType;

typedef struct LTNode {

LTDataType data;

struct LTNode* prev;

struct LTNode* next;

}LTNode;

//申请节点

LTNode* LTBuyNode(LTDataType x);

void LTInit(LTNode** pphead);

void LTPushBack(LTNode* phead, LTDataType x);

void LTPrint(LTNode* phead);

void LTPushFront(LTNode* phead, LTDataType x);

void LTPopBack(LTNode* phead);
//头删
void LTPopFront(LTNode* phead);

4.2.4-21.c(实现文件)

完整代码如下:

//头删

void LTPopFront(LTNode* phead) {

assert(phead && phead->next != phead);

LTNode* del = phead->next;

phead->next = del->next;

del->next->prev = phead;

free(del);

del = NULL;

}

4.3.test.c(实现文件)

代码如下:

LTPopFront(plist);

LTPrint(plist);

LTPopFront(plist);

LTPrint(plist);

LTPopFront(plist);

LTPrint(plist);

测试结果如下:

好了,关于双向链表的"头插"与"删除"操作 ,我们就先聊到这里。

写链表就像是在编织一张网,虽然指针的操作有时会让人晕头转向,但当你理清了节点之间的前后关系,那种逻辑闭环的快感是无与伦比的。

如果你觉得这篇笔记帮你避开了指针的"坑",或者让你对双向链表有了新的理解,请一定不要忘记点个关注!

后续我还会继续更新更多C语言的高级玩法和数据结构实战,关注我,让我们一起在01的世界里,把代码写得更优雅、更从容!我们下期见!

相关推荐
·醉挽清风·42 分钟前
学习笔记—MySQL—库表操作
笔记·学习·mysql
白小沫2 小时前
TortoiseSVN是什么?
学习
weixin_451431562 小时前
【学习笔记】微博视频页面ajax请求与响应数据分析
笔记·学习·音视频
清辞8533 小时前
尾盘选股法程序开发学习初期
学习
Century_Dragon4 小时前
让实训“活”起来——信息化综合实训考核平台助力汽车专业教学
学习
Dlrb12114 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
坚果派·白晓明4 小时前
【鸿蒙PC三方库移植适配框架解读系列】第一篇:Lycium C/C++ 三方库适配 — 概述与环境配置
c语言·开发语言·c++·harmonyos·开源鸿蒙·三方库·c/c++三方库
nashane4 小时前
HarmonyOS 6学习:PanGesture手势驱动月亮半圆轨迹“滚动”术
学习·harmonyos 5
叶~小兮5 小时前
K8S进阶核心综合学习笔记(持久化存储+特殊容器+调度管理)
笔记·学习·kubernetes
li星野5 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法