4.静态链表

用数组描述的链表称之为静态链表。
这种描述方法叫做游标实现法。

  • 我们对数组的第一个和最后一个元素做特殊处理,他们的data不存放数据。
  • 我们通常把未使用的数组元素称为备用链表。
  • 数组的第一个元素,即下标为0的那个元素的cur就存放备用链表的第一个结点的下标。即第0个元素的游标为5
  • 数组的最后一个元素,即下标为MAXSIZE-1的cur则存放第一个有数值的元素的下标,相当于单链表中的头结点作用。即第999个元素游标为1

静态链表存储结构:

 #define MAXSIZE 1000
 typedefstruct
 {
  ElemTypedata;  // 数据
  intcur;        // 游标(Cursor)
 } Component, StaticLinkList[MAXSIZE];
静态链表的插入:

每当进行插入时,可以从备用链表上取得第一个结点作为待插入的新结点。

要将B元素插入到A元素后面:


优点:

  • 在插入和删除操作时,只需要修改游标,不需要移动元素,从而改进了在顺序存储结构中的插入和删除操作需要移动大量元素的缺点。

缺点:

  • 没有解决连续存储分配(数组)带来的表长难以确定的问题。
  • 失去了顺序存储结构随机存取的特性。
问题:如何快速找到单向链表的中间节点?

方法1. 从头遍历单向链表,得到链表总长度L,然后再从头遍历L/2长度拿到中间节点,程序执行次数3L/2

方法2. 利用快慢指针,设置两个指针search和mid都指向单向链表的头节点。其中search指针的移动速度是mid的两倍。当search指针指向末尾节点的时候,mid指针就恰好在中间位置。也即标尺的思想。程序执行次数L/2

Status GetMidNode(LinkList L, ElemType *e)
{
    LinkList search, mid;
    mid = search = L;
    while (search->next != NULL)
    {
        //search“∆∂صƒÀŸ∂» « mid µƒ2±∂
        if (search->next->next != NULL)
        {
            search = search->next->next;
            mid = mid->next;
        }
        else
        {
            search = search->next;
        }
    }
    *e = mid->data;
    return OK;
}
问题:如何判断单向链表是否有环?
  • 方法一:使用p、q两个指针,p总是向前走,但q每次都从头开始走,对于每个节点,看p走的步数是否和q一样。如图,当p从6走到3时,用了6步,此时若q从head出发,则只需两步就到3,因而步数不等,出现矛盾,存在环。
  • 方法二:使用p、q两个指针,p每次向前走一步,q每次向前走两步,若在某个时候p == q,则存在环。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 转自:http://blog.csdn.net/oreo_go/article/details/52116214 ...
    YYT1992阅读 1,244评论 0 4
  • 目录 1、属性 2、链表和数组的区别 2.1、数组概述 2.2、数组和链表优缺点 2.3、链表和数组的比较 3、单...
    我哈啊哈啊哈阅读 2,925评论 1 41
  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 6,494评论 0 13
  • 繁华落尽沙洲冷 苦寒有情暗香来 人生若梦欲无边 一念清明任逍遥
    珉石阅读 155评论 0 0
  • 你看你看,石榴红了。 你看你看,樱桃熟了,能没人摘吗? 鼻子嗅出山林的秋到了,雉鸡焉能逃脱狐狸的怀抱!!! 冬雪了...
    诗趣阅读 380评论 0 0

友情链接更多精彩内容