c语言用单链表存储数据,数据结构—单链表(类C语言描写叙述)

单链表

1、链接存储方法

链接方式存储的线性表简称为链表(Linked List)。

链表的详细存储表示为:

① 用一组随意的存储单元来存放线性表的结点(这组存储单元既能够是连续的。也能够是不连续的)

② 链表中结点的逻辑次序和物理次序不一定同样。为了能正确表示结点间的逻辑关系,在存储每一个结点值的同一时候,还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link))

注意:

链式存储是最经常使用的存储方式之中的一个。它不仅可用来表示线性表。并且可用来表示各种非线性的数据结构。

2、链表的结点结构

┌──┬──┐

│data│next│

└──┴──┘

data域--存放结点值的数据域

next域--存放结点的直接后继的地址(位置)的指针域(链域)

注意:

①链表通过每一个结点的链域将线性表的n个结点按其逻辑顺序链接在一起的。

②每一个结点仅仅有一个链域的链表称为单链表(Single Linked List)。

3、头指针head和终端结点指针域的表示

单链表中每一个结点的存储地址是存放在其前趋结点next域中,而開始结点无前趋,故应设头指针head指向開始结点。

注意:

链表由头指针唯一确定,单链表能够用头指针的名字来命名。

【例】头指针名是head的链表可称为表head。

终端结点无后继,故终端结点的指针域为空,即NULL。

4、单链表的一般图示法

因为我们经常仅仅注重结点间的逻辑顺序,不关心每一个结点的实际位置,能够用箭头来表示链域中的指针,线性表(bat。cat,fat,hat。jat。lat。mat)的单链表就能够表示为下图形式。

5、单链表类型描写叙述

typedef char DataType; //如果结点的数据域类型为字符

typedef struct node{   //结点类型定义

DataType data;    //结点的数据域

struct node *next;//结点的指针域

}ListNode;

typedef ListNode *LinkList;

ListNode *p;

LinkList head;

注意:

①LinkList和ListNode *是不同名字的同一个指针类型(命名的不同是为了概念上更明白)

②LinkList类型的指针变量head表示它是单链表的头指针

③ListNode *类型的指针变量p表示它是指向某一结点的指针

6、指针变量和结点变量

┌────┬────────────┬─────────────┐

│    │    指针变量    │     结点变量      │

├────┼────────────┼─────────────┤

│  定义  │在变量说明部分显式定义  │在程序运行时,通过标准    │

│        │                        │函数malloc生成            │

├────┼────────────┼─────────────┤

│  取值  │ 非空时,存放某类型结点 │实际存放结点各域内容      │

│        │的地址                  │                          │

├────┼────────────┼─────────────┤

│操作方式│ 通过指针变量名訪问     │ 通过指针生成、訪问和释放 │

└────┴────────────┴─────────────┘

①生成结点变量的标准函数

p=( ListNode *)malloc(sizeof(ListNode));

//函数malloc分配一个类型为ListNode的结点变量的空间,并将其首地址放入指针变量p中

②释放结点变量空间的标准函数

free(p);//释放p所指的结点变量空间

③结点分量的訪问

利用结点变量的名字*p訪问结点分量

方法一:(*p).data和(*p).next

方法二:p-﹥data和p-﹥next

④指针变量p和结点变量*p的关系

指针变量p的值——结点地址

结点变量*p的值——结点内容

(*p).data的值——p指针所指结点的data域的值

(*p).next的值——*p后继结点的地址

*((*p).next)——*p后继结点

注意:

① 若指针变量p的值为空(NULL),则它不指向不论什么结点。此时。若通过*p来訪问结点就意味着訪问一个不存在的变量,从而引起程序的错误。

② 有关指针类型的意义和说明方式的详解,【參考C语言的有关资料】。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值