您现在的位置是:首页 >

线性表的链式存储结构与顺序存储 线性表 - 链式存储结构- 单链表的运算(三)

火烧 2022-05-05 20:20:05 1064
线性表 - 链式存储结构- 单链表的运算(三)    尾插法建带头结点的单链表  ①头结点及作用  头结点是在链表的开始结点之前附加一个结点 它具有两个优点:  ⒈由于开始结点的位置被存放在头结点的指

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

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

  ①头结点及作用

线性表的链式存储结构与顺序存储 线性表 - 链式存储结构- 单链表的运算(三)

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

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

  特殊处理;

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

  

  ②带头结点的单链表

  注意

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

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

  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;

  }

  注意

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

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

  ( ) 算法时间复杂度

lishixinzhi/Article/program/sjjg/201311/23309  
永远跟党走
  • 如果你觉得本站很棒,可以通过扫码支付打赏哦!

    • 微信收款码
    • 支付宝收款码