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

单链接的整表创建

 经常写swift写的没有写分号的习惯了~如果有看到的人见谅哈
  • 头插法
    *L = (LinkList)malloc(sizeof(Node)) (*L)->next = NULL for(int i = 0;i<n;i++){ p = (LinkList)malloc(sizeof(Node)) p->next = rand()%100 +1 p ->next = (*L)->next; (*L)->next = p }
  • 尾插法(外部一个指针记录当前最后一个元素的位置。不断更新最后一个元素)
    r = *L for(int i =0 ;i<n;i++){ p = (Node*)malloc(sizeof(Node)) p->data = 1 p ->next = r r = p } r->next = NULL

单链表的整表删除

  • 声明 p,q,
  • 将第一个节点赋值给p
  • 循环 q记录p—>next,释放p,p =q
    最后使头节点的指针域为NULL

静态链表

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

缺点:

  • 没有解决连续分配带来的表长难以确定的问题
  • 失去了顺序存储结构 随机存取的特性

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

循环链表

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

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

//记录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

双向循环链表的删除操作

  • p->prefix->next = p->next
  • p->next->prefix = p->prefix

总结

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文内容取自于小甲鱼的数据结构与算法。http://www.jianshu.com/p/230e6fde9c75 ...
    阿阿阿阿毛阅读 2,936评论 0 7
  • 1.线性表的定义 线性表:零个或多个数据元素的有限序列序列:也就是说元素之间是有顺序的,若元素存在多个,则第一个元...
    e40c669177be阅读 2,099评论 6 15
  • 前言 在之前的文章中, 大家还记得我的链表和结点、结点协议的名字么? 1.CHRSinglyLinkedListN...
    Chrisss阅读 1,597评论 3 3
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,482评论 1 3
  • 链表是线性表的链式存储方式,逻辑上相邻的数据在计算机内的存储位置不一定相邻,那么怎么表示逻辑上的相邻关系呢? 可以...
    rainchxy阅读 2,040评论 0 6