面试题之算法知识

线性表之静态链接,循环链表,双向链表

2017-07-22  本文已影响18人  沧州宁少

单链接的整表创建

 经常写swift写的没有写分号的习惯了~如果有看到的人见谅哈

单链表的整表删除

静态链表

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

缺点:

静态链表是为了 没有指针的高级语言设计的一种实现单链接能力的方法

循环链表

单链表中终端结点的指针端由空指针改为指向头结点,就使整个单链表形成了一个环。这种头尾相连的结构称为循环链表。

两个循环链表 合并成一个循环链表

//记录rearA的next的指向
p = rearA->next;

//rearA的末尾指向rearB的第一个结点。不是头结点

rearA->next = rearB->next->next;

q = rearB->next;

rearB->next = p ;

free(q);

双向链表

双向链表 是在单链表的每个结点中,再设置一个指向其前驱结点的指针域

单向链表可以存在循环链表。那么双向链表也可以存在循环链表。

双向链表的插入操作

s->prefix = p;

s->next = p->next;

p->next->prefix = s;

p->next = s

双向循环链表的删除操作

总结

双向链表对于单链表而言要复杂,因为多了prefix指针,对于插入和删除时候要格外小心。

上一篇 下一篇

猜你喜欢

热点阅读