数据结构--数据结构中的双链表结构(上)

  • 双链表顾名思义就是:两个单链表能够相互的链接起来。
  • 如图所示:
  • 废话不多说,我们直接上代码:首先要创建一个双链表就需要有:头文件,主文件和测试文件

分别是:(test.c List.h List.c)

  • 首先就是:初始化文件,它所对应的List.h 的代码为
cs 复制代码
#pragma once

#include<stdio.h>

typedef int LTDataType;
//定义双链表节点的结构

typedef struct ListNote
{
	LTDataType data;
	struct ListNote* next;
	struct ListNote* prev;
}LTNode;


//声明双链表中提供的方法

//初始化
LTNode* LTInit();   //申请节点

void LTDesTroy(LTNode* phead);
LTNode* LTBuyNode(LTDataType x);

这个就是头文件所包含的初始化代码。第一步:就是要定义一个:结构体。来代表说明要创造一个基本骨架。

它所对应的List.c的代码为

cs 复制代码
#define  _CRT_SECURE_NO_WARNINGS 1
#include"List.h"

void LTDesTroy(LTNode* phead)
{
	//对应头节点

	LTNode* pcur = phead->next;
	while (pcur != phead)
	{
		printf("%d->", pcur->data);
		pcur = pcur->next;
	}
	printf("\n");
}


//申请节点

LTNode* LTBuyNode(LTDataType x)
{
	LTNode* node = (LTNode*)malloc(sizeof(LTNode));
	if (node == NULL)
	{
		perror("malloc fail");
		exit();
	}
	node->data = x;
	node->next = node->prev = node;
}

LTNode* LTInit()
{
	LTNode* phead = LTBuyNode(-1);
	return phead;
}

首先就是要创建,申请一个空间,将所对应的x存入刚申请的空间中,这样做的好处就是:便于用x来指定下一个空间。方便第一个尾节点第二个的头节点相对应。

  • 下一步就是:尾插,为什么呢?是因为:给定一个空间,要在其空间的尾部插上x,这样才能传入到限一个空间的头部。

则对应尾插的List.h的代码是

cs 复制代码
void LTPushBack(LTNode* phead, LTDataType x);

相对来说比较的简单,它就是函数的声明而已:

则对应尾插的 List.c****的代码为

cs 复制代码
void LTPushBack(LTNode* phead, LTDataType x)
{
	assert(phead);//断言
	LTNode* newnode = LTBuyNode(x);

	newnode->prev = phead->prev;
	newnode->next = newnode;

	phead->prev->next = newnode;
	phead->prev = newnode;

}

简简单单几行代码就能搞定了。

  • 第二部:头插,和尾插基本一样,不过一个是在尾部,另一个是在头部插入。

则对应头插的List.h的代码是:

cs 复制代码
void LTPushFront(LTNode* phead, LTDataType x);

则对应头插的 List.c****的代码为

cs 复制代码
void LTPushFront(LTNode* phead, LTDataType x)

{
	assert(phead);
	LTNode* newnode = LTBuyNode(x);

	newnode->next = phead->next;

	newnode->prev = phead;

	phead->next->prev = newnode;

	phead->next = newnode;
}

基本上和尾插相似,但不完全一样,主要是:头插中,头部插入到下一个节点的头部。

相关推荐
两片空白9 分钟前
数据容器集合set/frozenset
数据结构
凌波粒14 分钟前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle15 分钟前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂36 分钟前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠1 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
代码中介商1 小时前
跳表:高效查找的链表黑科技
数据结构
兰令水1 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇1 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
.道阻且长.1 小时前
C++ string 操作指南:接口解析
java·c语言·开发语言·c++
2601_951645781 小时前
如何优雅地使用c语言编写爬虫
c语言·爬虫·网络请求·字符串处理·cspider