数据结构—单链表(类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语言的有关资料】。
数据结构—单链表(类C语言描写叙述)的更多相关文章
- 数据结构-二叉树的遍历(类C语言描写叙述)
		
遍历概念 所谓遍历(Traversal)是指沿着某条搜索路线.依次对树中每一个结点均做一次且仅做一次訪问.訪问结点所做的操作依赖于详细的应用问题. 遍历是二叉树上最重要的运算之中的一个,是二叉 ...
 - 数据结构-单链表-类定义2-C++
		
上一次的C++链表实现两个单链表的连接不太理想,此次听了一些视频课,自己补了个尾插法,很好的实现了两个链表的连接,当然了,我也是刚接触,可能是C++的一些语法还不太清楚,不过硬是花了一些时间尽量在数据 ...
 - 数据结构-单链表-类定义C++
		
原理可访问https://www.cnblogs.com/yang901112/p/11674333.html 头文件 #ifndef RLIST_H #define RLIST_H #include ...
 - C语言数据结构-单链表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作
		
1.数据结构-单链表的实现-C语言 typedef struct LNode { int data; struct LNode* next; } LNode,*LinkList; //这两者等价.Li ...
 - python算法与数据结构-单链表(38)
		
一.链表 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的.链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成.每个结点包括 ...
 - C# 数据结构--单链表
		
什么是单链表 这两天看到很多有关单链表的面试题,对单链表都不知道是啥的我.经过学习和整理来分享一下啥是单链表和单链表的一些基本使用方法.最后看些网上有关单链表的面试题代码实例. 啥是单链表? 单链表是 ...
 - 设计模式-适配器模式(Go语言描写叙述)
		
在上一篇博客设计模式-策略模式(Go语言描写叙述)中我们用最简单的代码用go语言描写叙述了设计模式中的策略模式,用最简单的实例来描写叙述相信能够让刚開始学习的人能够非常轻松的掌握各种设计模式.继上篇博 ...
 - python实现数据结构单链表
		
#python实现数据结构单链表 # -*- coding: utf-8 -*- class Node(object): """节点""" ...
 - 数据结构——单链表java简易实现
		
巩固数据结构 单链表java实现 单链表除了表尾 每个几点都有一个后继 结点有数据和后继指针组成 通过构建表头和表尾(尾部追加需要)两个特殊几点 实现单链表的一些操作,代码如下 package co ...
 
随机推荐
- C++中 pair 的使用方法
			
#include<iostream> #include<string> #include<map> using namespace std; // pair简单讲就 ...
 - PySide2运行出错问题解决
			
PySide2是QT官方出的Python的QT封装, 不过默认安装运行时候会有一些小问题, 可能是系统里已经安装过其他版本QT的原因, 会报错如下: PySide2 qt.qpa.plugin: Co ...
 - ROS-SLAM-自主导航
			
前言:无. 前提:已下载并编译了相关功能包集,如还未下载,可通过git下载:https://github.com/huchunxu/ros_exploring.git 一.启动仿真环境 cd ~/ca ...
 - bootstrap在input框中加入icon图标
			
<form class="form-horizontal"> <div class="form-group has-feedback"> ...
 - reflect  反射结合集合泛型的总结
			
集合泛型: 可以放任何对象的 ArrayList ArrayList list = new ArrayList(); 没有限定泛型类型. list.add("lilin");l ...
 - ABBYY FineReader去他的光棍节,我要我的双十一
			
今天就是双十一,全民剁手的双十一,一年仅一次的双十一,不只是半价的双十一.....此时此刻,多少钱拿起手机在疯狂购物,又有多少人死守着电脑,不敢怠慢一丁点机会,买着买着购物车就空了,然后才发现,咦!超 ...
 - PAT 天梯赛练习集 L2-004. 这是二叉搜索树吗?
			
题目链接: https://www.patest.cn/contests/gplt/L2-004 一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点, 其左子树中所有结点的键值小于该结点 ...
 - IOS - 6\7下UINavigationBar的颜色的方法改变 ——转载http://www.th7.cn/Program/IOS/201310/155057.shtml
			
IOS7下设置UINavigationBar的颜色的方法已经改变(当然如果是用自定义图片的话请忽略---) 首先是区别iOS7和之前版本的方法如下: //如果是iOS7以前的话if (floor(NS ...
 - HDU 1205 吃糖果(水题)
			
链接:传送门 思路:思维僵硬了,僵硬...... 简单的插隔板思想......选出来数量最多的糖果种类X,假设X数量为MAX,然后以X作为"隔板",形成X _ X _ X _ X ...
 - jboss <context /> 配置虚拟路径,映射本地文件
			
这个目录下的server.xml <host><host/>标签中添加: <Context path="/file" docBase="D: ...