4.静态链表

2018-08-03  本文已影响4人  芝麻酱的简书

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

静态链表存储结构:

 #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;
}
问题:如何判断单向链表是否有环?
上一篇 下一篇

猜你喜欢

热点阅读