码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法&数据结构 - 线性表之静态链表、循环链表、双向链表


            除了上文所介绍的最常见的单链表,本文简单介绍一下线性的其他链式存储结构表,本篇较多代码。

    目录

    静态链表

    插入、删除操作

    优缺点

    循环链表

    双向链表

    线性表总结


    静态链表

            如果没有指针,无法使用指针指向下一个元素地址,链表也就无法按我们之前所说的那样实现了。那怎么办能既存储数据域(data)的信息又存储指针域(cur)的信息?

            我们用数组来描述链表,这样的链表就叫做静态链表。

    1. #define MAXSIZE 1000 /* 存储空间初始分配量 */
    2. /* 线性表的静态链表存储结构 */
    3. typedef struct
    4. {
    5. ElemType data;
    6. int cur; /* 游标(Cursor) ,为0时表示无指向 */
    7. } Component,StaticLinkList[MAXSIZE];

    插入、删除操作

    1. /* 插入 */
    2. Status ListInsert(StaticLinkList L, int i, ElemType e)
    3. {
    4. int j, k, l;
    5. k = MAXSIZE - 1; /* 注意k首先是最后一个元素的下标 */
    6. if (i < 1 || i > ListLength(L) + 1)
    7. return ERROR;
    8. j = Malloc_SSL(L); /* 获得空闲分量的下标 */
    9. if (j)
    10. {
    11. L[j].data = e; /* 将数据赋值给此分量的data */
    12. for(l = 1; l <= i - 1; l++) /* 找到第i个元素之前的位置 */
    13. k = L[k].cur;
    14. L[j].cur = L[k].cur; /* 把第i个元素之前的cur赋值给新元素的cur */
    15. L[k].cur = j; /* 把新元素的下标赋值给第i个元素之前元素的ur */
    16. return OK;
    17. }
    18. return ERROR;
    19. }
    20. /* 删除 */
    21. Status ListDelete(StaticLinkList L, int i)
    22. {
    23. int j, k;
    24. if (i < 1 || i > ListLength(L))
    25. return ERROR;
    26. k = MAXSIZE - 1;
    27. for (j = 1; j <= i - 1; j++)
    28. k = L[k].cur;
    29. j = L[k].cur;
    30. L[k].cur = L[j].cur;
    31. Free_SSL(L, j);
    32. return OK;
    33. }

    优缺点

    优点

    • 插入、删除时修改游标不需要移动元素,改进了顺序结构中原本复杂的插入、删除操作

    缺点 

    • 连续存储空间表长难以确定;
    • 失去了随机存取的特性。

    循环链表

    最后一个结点的指针域指到头结点,链表闭合。

    将两个循环链表连接起来:

    1. p=rearA->next; /* 保存A表的头结点 */
    2. rearA->next=rearB->next->next; /* 将本是指向B表的第一个结点(不是头结点)*/
    3. /* 赋值给reaA->next*/
    4. q=rearB->next;
    5. rearB->next=p; /* 将原A表的头结点赋值给rearB->next */
    6. free(q); /* 释放q */

    双向链表

            我们的指针按顺序指下来,在单链表中是不可逆的,也就是通过上一个结点可以找到下一个,但下一个节点找不到上一个。在每个节点中,再设置一个指向前一节点的指针,就成了双向链表。

     如果是循环的双项链表呢?

    1. /*线性表的双向链表存储结构*/
    2. typedef struct DulNode
    3. {
    4. ElemType data;
    5. struct DuLNode *prior; /*直接前驱指针*/
    6. struct DuLNode *next; /*直接后继指针*/
    7. } DulNode, *DuLinkList;
    8. p->next->prior = p = p->prior->next
    9. s - >prior = p; /*把p赋值给s的前驱*/
    10. s -> next = p -> next; /*把p->next赋值给s的后继*/
    11. p -> next -> prior = s; /*把s赋值给p->next的前驱*/
    12. p -> next = s; /*把s赋值给p的后继*/
    13. p->prior->next=p->next; /*把p->next赋值给p->prior的后继*/
    14. p->next->prior=p->prior; /*把p->prior赋值给p->next的前驱*/
    15. free(p); /*释放结点*/

    线性表总结

            线性表是最基本、最简单、也是最常用的一种数据结构。线性表是数据结构中的一种,一个线性表是n个具有相同特性的数据元素的有限序列。

     

     

    欢迎点赞、收藏、评论区交流,转载标明出处。

    -----------------------------

    上文连接:

    算法&数据结构 - 线性表及其链式存储结构_昊昊该干饭了的博客-CSDN博客本篇主要介绍线性表另一种存储形式,链式存储结构及其操作方法,本篇中量代码。https://blog.csdn.net/qq_52213943/article/details/125824927

    下文连接:

    敬请期待:栈与队列详解

  • 相关阅读:
    Linux新手教程||Linux vi/vim
    MySQL数据库的SQL语句
    DataBinding 进阶用法
    【网络通信 -- WebRTC】项目实战记录 -- mediasoup android 适配 webrtc m94
    从入局到破局:商家怎样挖掘视频号的新增量?
    考研:研究生考试(五天学完)之《线性代数与空间解析几何》研究生学霸重点知识点总结之第七课二次型
    Spring Cloud Gateway现高风险漏洞,建议采取措施加强防护
    猿创征文|我的焚膏继晷之路
    鱼类eDNA生物多样性检测重磅来袭!
    解决 Maven package 命令报错程序包 sun.* 不存在
  • 原文地址:https://blog.csdn.net/qq_52213943/article/details/125879485
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号