单链表

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语言的有关资料】。

转载于:https://www.cnblogs.com/liguangsunls/p/6943203.html

数据结构—单链表(类C语言描写叙述)相关推荐

  1. 二叉树的遍历实验报告C语言,数据结构-二叉树的遍历(类C语言描写叙述)

    遍历概念 所谓遍历(Traversal)是指沿着某条搜索路线.依次对树中每一个结点均做一次且仅做一次訪问.訪问结点所做的操作依赖于详细的应用问题. 遍历是二叉树上最重要的运算之中的一个,是二叉树上进行 ...

  2. c语言单链表功能,[数据结构]单链表(C语言)的各种功能

    06-03阅读200,000 + 链表是一种常见的基本数据结构,在此充分利用了结构指针. 链表可以动态存储和分配,即链表是一个功能非常强大的数组. 他可以在节点中定义多种数据类型,并可以根据需要随意添 ...

  3. 数据结构-单链表基本操作-C语言代码

    单链表基本操作 1.头插法建立单链表 2.尾插法建立单链表 3.查找结点 3.修改结点 4.插入结点 5.删除结点 本篇只有c语言代码,具体思路讲解请看这篇博客:数据结构-线性结构-单链表 1.头插法 ...

  4. 数据结构上机-尾、头插法建立单链表-单链表遍历C语言完整代码实现

    点击此处跳转视频链接:数据结构上机-尾.头插法建立单链表-单链表遍历C语言完整代码实现

  5. C语言数据结构 单链表的建立、遍历、查找、插入和删除操作

    参考文献 本博文为半摘记性质 -- 声明:全文主干部分摘自 [1] 杨智明. 数据结构(C语言版)[M]. 第一版. 北京:北京理工大学出版社, 2016. [2] 严蔚敏, 李冬梅, 吴伟民. 数据 ...

  6. 数据结构-单链表基本操作(C语言实现)

    参考书:王道考研数据结构 (此贴为博主学习408的笔记,因博主也是学习者,个人总结如有错误欢迎指正.如有侵权请告知,马上删除致歉)​​ 单链表定义 单链表是线性表的链式存储,通过一组任意的存储单元来存 ...

  7. C语言数据结构单链表链表

    数据结构–单链表 学习了顺序表,我们发现顺序表在向里面存放数据的时候很麻烦,比如我们要使用头插法存放一个数据到顺序表的时候,我们要将整个表都向后挪一位,这个操作就让人很难受.那么有没有一种结构可以让我 ...

  8. php链表和联表的区别,PHP_浅谈PHP链表数据结构(单链表),链表:是一个有序的列表,但 - phpStudy...

    浅谈PHP链表数据结构(单链表) 链表:是一个有序的列表,但是它在内存中是分散存储的,使用链表可以解决类似约瑟夫问题,排序问题,搜索问题,广义表 单向链表,双向链表,环形链表 PHP的底层是C,当一个 ...

  9. 20175330 数据结构-单链表(选做)

    要求 参见附件,补充MyList.java的内容,提交运行结果截图(全屏) 课下推送代码到码云 ``` public class MyList {     public static void mai ...

最新文章

  1. 让页面先发送ajax,Ajax, 了解一下
  2. (转)利用libcurl和国内著名的两个物联网云端通讯的例程, ubuntu和openwrt下调试成功(四)...
  3. Spring整合Quartz定时发送邮件
  4. linux 定时清理tomcat日志
  5. python的setup.py文件及其常用命令
  6. ARM 汇编学习——编写简单的ARM汇编程序
  7. mac svn 设置代理
  8. 2012.4.19总结(一)
  9. 资源 | 有没有必要把机器学习算法自己实现一遍?
  10. 十六、K8s安全管理与资源限制
  11. iOS - 获取状态栏和导航栏尺寸(宽度和高度)
  12. MicroMsg.SDK.WXMediaMessage: checkArgs fail, thumbData is invalid
  13. Mac本配置adb环境,通过adb安装apk。
  14. vim 快捷键 总结-编辑文件
  15. DNA损伤修复基因数据库
  16. Excel数据透视表经典教程十《值的汇总及显示方式》
  17. 年后要不要跳槽?看完这篇产业互联网趋势分析再决定吧!
  18. Linux 安装cacti
  19. “华为起诉美国”事件进展:美国联邦法院给美国政府发传票
  20. php文件格式还原,硬盘raw格式还原ntfs

热门文章

  1. C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP),多多宜善
  2. 虚拟语气和推测(二)
  3. 每天进步一点点《ML - 从极大似然到EM算法》
  4. 字符编码、常见字符集解析(ASCII、Unicode、UTF-8、GB2312等)
  5. Going Further with Point Pair Features: PPF, 如何走的更远?
  6. LeetCode —— 146. LRU缓存机制(Python)
  7. R语言中package ‘xxxx’ is not available (for R version 3.2.5)解决
  8. Markdown--表格语法
  9. CMD提取文件名技巧
  10. leetcode53. 最大子序和详解——pygo