单链表

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

数据结构—单链表(类C语言描写叙述)的更多相关文章

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

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

  2. 数据结构-单链表-类定义2-C++

    上一次的C++链表实现两个单链表的连接不太理想,此次听了一些视频课,自己补了个尾插法,很好的实现了两个链表的连接,当然了,我也是刚接触,可能是C++的一些语法还不太清楚,不过硬是花了一些时间尽量在数据 ...

  3. 数据结构-单链表-类定义C++

    原理可访问https://www.cnblogs.com/yang901112/p/11674333.html 头文件 #ifndef RLIST_H #define RLIST_H #include ...

  4. C语言数据结构-单链表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作

    1.数据结构-单链表的实现-C语言 typedef struct LNode { int data; struct LNode* next; } LNode,*LinkList; //这两者等价.Li ...

  5. python算法与数据结构-单链表(38)

    一.链表 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的.链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成.每个结点包括 ...

  6. C# 数据结构--单链表

    什么是单链表 这两天看到很多有关单链表的面试题,对单链表都不知道是啥的我.经过学习和整理来分享一下啥是单链表和单链表的一些基本使用方法.最后看些网上有关单链表的面试题代码实例. 啥是单链表? 单链表是 ...

  7. 设计模式-适配器模式(Go语言描写叙述)

    在上一篇博客设计模式-策略模式(Go语言描写叙述)中我们用最简单的代码用go语言描写叙述了设计模式中的策略模式,用最简单的实例来描写叙述相信能够让刚開始学习的人能够非常轻松的掌握各种设计模式.继上篇博 ...

  8. python实现数据结构单链表

    #python实现数据结构单链表 # -*- coding: utf-8 -*- class Node(object): """节点""" ...

  9. 数据结构——单链表java简易实现

    巩固数据结构 单链表java实现 单链表除了表尾 每个几点都有一个后继 结点有数据和后继指针组成  通过构建表头和表尾(尾部追加需要)两个特殊几点 实现单链表的一些操作,代码如下 package co ...

随机推荐

  1. node-webkit 屏幕截图功能

    做 IM 屏幕截图是少不了的,之前 windows 版本是调用的 qq 输入法的截图功能,这个版本又再次尝试自己实现发现是可以的,getusermedia 的权限很高,代码如下 <!DOCTYP ...

  2. (转)c++ typedef 函数指针详细说明

    转自:http://blog.csdn.net/future200x/article/details/5350134 一个函数在编译时被分配一个入口地址,将这个入口地址称为函数的指针,可以用一个指针变 ...

  3. bzoj5216: [Lydsy2017省队十连测]公路建设

    题目思路挺巧妙的. 感觉应该可以数据结构一波,发现n很小可以搞搞事啊.然后又发现给了512mb,顿时萌生大力线段树记录的念头 一开始想的是记录节点的fa,然后发现搞不动啊?? 但其实边肯定最多只有n- ...

  4. Java-SpringCloud:Spring Cloud 是什么

    ylbtech-Java-SpringCloud:Spring Cloud 是什么 1.返回顶部 1. 一.概念定义       Spring Cloud是一个微服务框架,相比Dubbo等RPC框架, ...

  5. AMD cpu 下 Pytorch 多卡并行卡死问题解决

    dataparallel not working on nvidia gpus and amd cpus   https://github.com/pytorch/pytorch/issues/130 ...

  6. ubuntu中不能远程连接解决

    今天装好ubuntu19.04之后不能远程连接,网上找了很久终于自己解决了.ap 步骤如下:希望对各位有用,哪里不对请指出 第一步我们需要加载openssh-server   等待加载完毕后,     ...

  7. BZOJ 4129 树上带修莫队+线段树

    思路: 可以先做做BZOJ3585 是序列上的mex 考虑莫队的转移 如果当前数字出现过 线段树上把它置成1 对于询问 二分ans 线段树上查 0到ans的和 是不是ans+1 本题就是把它搞到了序列 ...

  8. 洛谷P3327 [SDOI2015]约数个数和(莫比乌斯反演)

    题目描述 设d(x)为x的约数个数,给定N.M,求 \sum^N_{i=1}\sum^M_{j=1}d(ij)∑i=1N​∑j=1M​d(ij) 输入输出格式 输入格式: 输入文件包含多组测试数据.第 ...

  9. WEB前端开发常用的优化技巧汇总

    减少HTTP请求次数或者减少请求数据的大小 页面中每发送一次HTTP请求,都需要完成请求+响应这个完整的HTTP事务,会消耗一些时间,也可能会导致HTTP链接通道的堵塞,为了提高页面加载速度和运行的性 ...

  10. 基于XMPP利用openfire简单的即时通讯

    功能的实现结果:能够使自己编写客户端与spark客户端信息通讯,将接受到的信息更新到textview上. 1.下载openfire并安装.设置域名,添加用户 2.下载安装spark客户端 3.jar包 ...