知识大全 线性表 - 链式存储结构- 单链表的运算(三)

Posted 结点

篇首语:未曾哭过长夜的人,不足以语人生。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 线性表 - 链式存储结构- 单链表的运算(三)相关的知识,希望对你有一定的参考价值。

  ( ) 尾插法建带头结点的单链表

  ①头结点及作用

  头结点是在链表的开始结点之前附加一个结点 它具有两个优点:

  ⒈由于开始结点的位置被存放在头结点的指针域中 所以在链表的第一个位置上的操作就和在表的其它位置上操作一致 无须进行

  特殊处理;

  ⒉无论链表是否为空 其头指针都是指向头结点的非空指针(空表中头结点的指针域空) 因此空表和非空表的处理也就统一了

  

  ②带头结点的单链表

  注意

  头结点数据域的阴影表示该部分不存储信息 在有的应用中可用于存放表长等附加信息

  ③尾插法建带头结点链表算法

  LinkList CreatListR (void)

  //用尾插法建立带头结点的单链表

  char ch;

  LinkList head=(ListNode *)malloc(sizeof(ListNode));//生成头结点

  ListNode *s *r; //工作指针

  r=head; // 尾指针初值也指向头结点

  while((ch=getchar())!= \\n )

  s=(ListNode *)malloc(sizeof(ListNode));//生成新结点

  s >data=ch; //将读入的数据放入新结点的数据域中

  r >next=s;

  r=s;

  

  r >next=NULL;//终端结点的指针域置空 或空表的头结点指针域置空

  return head;

  

  注意

  上述算法里 动态申请新结点空间时未加错误处理 这对申请空间极少的程序而言不会出问题 但在实用程序里 尤其是对空间需求

  较大的程序 凡是涉及动态申请空间 一定要加入错误处理以防系统无空间可供分配

  ( ) 算法时间复杂度

cha138/Article/program/sjjg/201311/23309

相关参考