当前位置: 首页 > news >正文

数据结构——双向链表

上一章:数据结构——单向链表(C语言版)-CSDN博客

目录

什么是双向链表?

双向链表的节点结构

双向链表的基本操作

完整的双向链表示例

总结


什么是双向链表?

双向链表是一种常见的数据结构,它由一系列节点组成,每个节点包含两个指针:一个指向前一个节点,一个指向后一个节点。双向链表可以在任意位置高效地插入和删除节点,相比单向链表,双向链表可以双向遍历,但相应地需要更多的内存空间存储额外的指针。

双向链表的节点结构
typedef struct Node {int data;struct Node* prev;struct Node* next;
} Node;
双向链表的基本操作
  1. 初始化双向链表

    Node* initLinkedList() {Node* head = (Node*)malloc(sizeof(Node));head->prev = NULL;head->next = NULL;return head;
    }
  2. 插入节点 

    void insertNode(Node* prevNode, int data) 
    { Node* newNode = (Node*)malloc(sizeof(Node)); 
    newNode->data = data;newNode->prev = prevNode;newNode->next = prevNode->next;prevNode->next->prev = newNode;prevNode->next = newNode;}

    3.删除节点

void deleteNode(Node* delNode) {delNode->prev->next = delNode->next;delNode->next->prev = delNode->prev;free(delNode);
}
  1. 遍历双向链表
    void printLinkedList(Node* head) {Node* current = head->next;while (current != NULL) {printf("%d ", current->data);current = current->next;}printf("\\n");
    }
完整的双向链表示例
#include <stdio.h>
#include <stdlib.h>typedef struct Node {int data;struct Node* prev;struct Node* next;
} Node;Node* initLinkedList() {Node* head = (Node*)malloc(sizeof(Node));head->prev = NULL;head->next = NULL;return head;
}void insertNode(Node* prevNode, int data) {Node* newNode = (Node*)malloc(sizeof(Node));newNode->data = data;newNode->prev = prevNode;newNode->next = prevNode->next;prevNode->next->prev = newNode;prevNode->next = newNode;
}void deleteNode(Node* delNode) {delNode->prev->next = delNode->next;delNode->next->prev = delNode->prev;free(delNode);
}void printLinkedList(Node* head) {Node* current = head->next;while (current != NULL) {printf("%d ", current->data);current = current->next;}printf("\\n");
}int main() {Node* head = initLinkedList();insertNode(head, 1);insertNode(head->next, 2);insertNode(head->next->next, 3);printLinkedList(head);deleteNode(head->next);printLinkedList(head);return 0;
}
总结

通过上述代码示例,我们实现了双向链表的基本操作,包括初始化、插入和删除节点,以及遍历链表。双向链表是一种灵活且高效的数据结构,适用于需要频繁插入和删除操作的场景。通过深入理解双向链表的实现原理,我们可以更好地应用它解决实际问题。

由以上内容我们其实就可以看到在应用与理解层面,双向链表相较于单向链表有很大的优势,但在具体应用中还需要我们实际情况实际判断。

感谢观看,还请各位大佬点赞支持以下!!!

相关文章:

  • 利用图像识别进行疾病诊断
  • 【数据结构】顺序表的实现——静态分配
  • 气象预测新篇章:Python人工智能的变革力量
  • .helper勒索病毒的最新威胁:如何恢复您的数据?
  • 分类任务中的评估指标:Accuracy、Precision、Recall、F1
  • CUDA从入门到放弃(七):流( Streams)
  • ubuntu 不产生core dump 文件
  • 数据库内数据已清除,刷新后又出现
  • Google 邀请您参加 Build with AI 2024 线下活动
  • 55、Qt/事件机制相关学习20240326
  • Java 多态、包、final、权限修饰符、静态代码块
  • 数据结构面试常见的问题以及详细的解答(附带相关知识点)
  • Java 实现缓存的三种方式
  • [力扣DP]72. 编辑距离
  • 机器学习——元学习
  • 【笔记】你不知道的JS读书笔记——Promise
  • 【刷算法】从上往下打印二叉树
  • IndexedDB
  • js学习笔记
  • Mysql5.6主从复制
  • nodejs:开发并发布一个nodejs包
  • Swift 中的尾递归和蹦床
  • TiDB 源码阅读系列文章(十)Chunk 和执行框架简介
  • 从零开始的无人驾驶 1
  • 记一次删除Git记录中的大文件的过程
  • 经典排序算法及其 Java 实现
  • 开源SQL-on-Hadoop系统一览
  • 面试总结JavaScript篇
  • 爬虫进阶 -- 神级程序员:让你的爬虫就像人类的用户行为!
  • 浅谈Golang中select的用法
  • 与 ConTeXt MkIV 官方文档的接驳
  • 在electron中实现跨域请求,无需更改服务器端设置
  • ​LeetCode解法汇总1410. HTML 实体解析器
  • #if和#ifdef区别
  • (03)光刻——半导体电路的绘制
  • (04)Hive的相关概念——order by 、sort by、distribute by 、cluster by
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (webRTC、RecordRTC):navigator.mediaDevices undefined
  • (超简单)使用vuepress搭建自己的博客并部署到github pages上
  • (读书笔记)Javascript高级程序设计---ECMAScript基础
  • (二十一)devops持续集成开发——使用jenkins的Docker Pipeline插件完成docker项目的pipeline流水线发布
  • (附源码)计算机毕业设计大学生兼职系统
  • (转)memcache、redis缓存
  • (转)ORM
  • ../depcomp: line 571: exec: g++: not found
  • .NET CORE 第一节 创建基本的 asp.net core
  • .NET HttpWebRequest、WebClient、HttpClient
  • .NET MAUI学习笔记——2.构建第一个程序_初级篇
  • .net mvc 获取url中controller和action
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET3.5下用Lambda简化跨线程访问窗体控件,避免繁复的delegate,Invoke(转)
  • .NET学习全景图
  • ??在JSP中,java和JavaScript如何交互?
  • @KafkaListener注解详解(一)| 常用参数详解
  • @RequestBody与@ModelAttribute