mysql 线性表_数据结构之线性表

概要

参考《大话数据结构》,把常用的基本数据结构梳理一下。

线性表

定义

线性表(List):零个或多个数据元素的有限序列。

若将线性表记为 \((a_1, \cdots, a_{i-1}, a_i, a_{i+1}, \cdots, a_n)\),则表中 \(a_{i-1}\) 领先于 \(a_i\),\(a_i\) 领先于 \(a_{i+1}\),称 \(a_{i-1}\) 是 \(a_i\) 的直接前驱元素,\(a_{i+1}\) 是 \(a_i\) 的直接后继元素。线性表的元素个数 \(n\) 定义为线性表的长度,当 \(n=0\) 时,称为空表。

线性表的顺序存储结构

线性表的顺序存储结构就是在内存中找了块地儿,通过占位的形式,把一定的内存空间给占了,然后把相同数据类型的数据元素依次存放在这块空地中。因此可以用一维数组来实现顺序存储结构,即把第一个数据元素存到数组下标为 \(0\) 的位置中,接着把线性表相邻的元素存储在数组中相邻的位置。

来看看线性表的顺序存储结构的代码。

# define MAXSIZE 20 //存储空间初始分配量

typedef int ElemType; // ElemType 类型根据实际情况而定,这里假设为 int

typedef struct

{

ElemType data[MAXSIZE]; // 数组存储数据元素,最大值为 MAXSIZE

int length; // 线性表当前长度

}SqList;

这里注意描述顺序存储结构需要三个属性:

存储空间的起始位置:数组 data,它的存储位置就是存储空间的存储位置

线性表的最大存储容量:数组长度 MAXSIZE(注意不等于线性表的长度)。

线性表的当前长度:length.

线性表顺序存储结构的优缺点

线性表的顺序存储结构,在存、读数据时,不管是哪个位置,时间复杂度都是 \(O(1)\);而插入或删除时,时间复杂度都是 \(O(n)\). 这就说明它比较适合元素个数不太变化,而更多是存取数据的应用。优缺点总结如下:

优点:

无须为表示表中元素之间的逻辑关系而增加额外的存储空间

可以快速地存取表中任一位置的元素

缺点:

插入和删除操作需要移动大量元素

当线性表长度变化较大时,难以确定存储空间的容量

造成存储空间的 “碎片”

线性表的链式存储结构

在链式结构中,除了要存数据元素信息外,还要存储它的直接后继元素的存储地址,我们把存储数据元素信息的域称为数据域,把存储直接后继位置的域称为指针域。指针域中存储的信息称做指针或链。这两部分信息组成数据元素 \(a_i\) 的存储映像,称为结点。\(n\) 个结点链结成一个链表,即为线性表 \((a_1, a_2, \cdots, a_n)\) 的链式存储结构*,因为此链表的每个结点只包含一个指针域,所以叫做单链表**。

对于线性表来说,总得有个头有个尾,我们把链表中第一个结点的存储位置叫做头指针,那么整个链表的存取就必须是从头指针开始进行了。之后的每一个结点,其实就是上一个后继指针指向的位置。最后一个结点的指针为“空”(通常用 NULL 或 “^” 符号来表示)。

有时,为了更加方便地对链表进行操作,会在单链表的第一个结点前附设一个结点,称为头结点。头结点的数据域可以不存储任何信息,也可以存储如线性表的长度等附加信息,头结点的指针域存储指向第一个结点的指针,如图

635104ff6feac4ca06248011b7a90fd5.png

注意头指针与头结点的异同点:

头指针:

头指针是指链表指向第一个结点的指针,若链表有头结点,则是指向头结点的指针

头指针具有标识作用,所以常用头指针冠以链表的名字

无论链表是否为空,头指针均不为空。头指针是链表的必要元素

头结点

头结点是为了操作的统一和方便而设立的,放在第一元素的结点之前,其数据域一般无意义(也可存放链表的长度)

有了头结点,对在第一元素结点前插入结点和删除第一结点,其操作与其它结点的操作就统一了

头结点不一定是链表必须要素

来看看线性表的链式存储结构的代码。

// 线性表的单链表存储结构

typedef struct Node

{

ElemType data;

struct Node *next;

}Node;

typedef struct Node *LinkList; // 定义 LinkList

从这个结构定义中,我们也就知道,结点由存放数据元素的数据域存放后继结点地址的指针域组成。假设 \(p\) 是指向线性表第 \(i\) 个元素的指针,则该结点 \(a_i\) 的数据域我们可以用 \(p->data\) 来表示,\(p->data\) 的值是一个数据元素,结点 \(a_i\) 的指针域可以用 \(p->next\) 来表示,\(p->next\) 的值是一个指针,指向第 \(i+1\) 个元素,即指向 \(a_{i+1}\) 的指针。也就是说,如果 \(p->data = a_i\),那么 \(p->next->data = a_{i+1}\).

单链表结构与顺序存储结构优缺点

简单地对单链表结构和顺序结构做对比:

7cca8f2171450bdbe3565689da8a56ee.png

通过上面的对比,我们可以得出一些经验性的结论

若线性表需要频繁查找,很少进行插入和删除操作时,宜采用顺序存储结构。若需要频繁插入和删除时,宜采用单链表结构。

当线性表中的元素个数变化较大或者根本不知道有多大时,最好用单链表结构,这样可以不需要考虑存储空间的大小问题。如果事先知道线性表的大致长度,比如一年 12 个月,一周就是 7 天,这种用顺序存储结构效率会好很多

总之,线性表的存储结构和单链表结构各有优缺点,视实际情况而定。

最后简单说一下静态链表。静态链表是用数组描述的链表,我们让数组的元素都是由两个数域组成, data 和 cur. 也就是说,数组的每个下标都对应一个 data 和下一个 cur. 数据域 data,用来存放数据元素,也就是通常我们要处理的数据;而游标 cur 相当于单链表中的 next 指针,存放该元素的后继在数组中的下标。所以它还有个别名:游标实现法。它有单链表的插入和删除操作性能,但是没有解决连续存储分配带来的表长难以确定的问题,而且失去了顺序存储结构随机存取的特性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/542764.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用JavaScript修改浏览器URL地址栏的实现代码

现在的浏览器里,有一个十分有趣的功能,你可以在不刷新页面的情况下修改浏览器URL;在浏览过程中.你可以将浏览历史储存起来,当你在浏览器点击后退按钮的时候,你可以冲浏览历史上获得回退的信息,这听起来并不复杂,是可以…

ruby array_在Ruby中使用Array.pop和Array.shift方法从Array中删除元素

ruby arrayRuby Array.pop和Array.shift方法 (Ruby Array.pop and Array.shift methods) If you are reading an article that is related to deleting elements from the instance of Array class then it is expected from you that you are aware of the basic things relat…

python语言百分号的含义_python中百分号意思的是什么

python中百分号意思的是什么 发布时间:2020-07-09 16:38:13 来源:亿速云 阅读:158 python中百分号意思的是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有…

MATLAB学习——矩阵

矩阵矩阵运算算术运算基本算术运算点运算关系运算逻辑运算元素处理取整取模和取余矩阵分析与处理矩阵行列式、秩与迹、特征值分析矩阵的逆与线性方程组求解矩阵的分解与变换矩阵运算 算术运算 基本算术运算 #检查矩阵阶数[n,m] size(A),l length(A) A [1 2;3 4] B [1 1;…

sqldeveloper mysql迁移_通过SQL Developer工具将MySQL数据库内容迁移至Oracle的步骤

通过SQL Developer工具将MySQL数据库内容迁移至Oracle的步骤发布时间:2020-06-08 15:52:18来源:51CTO阅读:210作者:三月本篇文章给大家主要讲的是关于通过SQL Developer工具将MySQL数据库内容迁移至Oracle的步骤的内容&#xff0c…

未能成功加载扩展程序_【JAVA虚拟机(JVM)精髓】09-几种不同的类加载器

持续更新JVM相关知识,敬请关注:Java虚拟机精髓专栏​zhuanlan.zhihu.com上一节说了下类加载器和类加载过程。这一节我们看下几种不同的类加载器。JVM支持的类加载器有两类,分别是引导类加载器和自定义加载器。这里的自定义自定义加载器&#…

Oracle .事物,提交,回滚

事物(transaction) -->作为单个逻辑工作单元执行的一系列操作(要么全部成功要么全部失败) 提交(commit) -->系列操作全部成功的场合才会执行 回滚(rollback) -->系列操作其…

perl 哈希数组的哈希_第一个元素使用哈希在数组中出现K次

perl 哈希数组的哈希Prerequisite: Hashing data structure 先决条件: 哈希数据结构 Problem statement: 问题陈述: Find the first element occurring K times in the array. 查找数组中出现K次的第一个元素。 Example: 例: Input array…

图片md5修改工具_如何修改视频和图片的MD5,用电脑自带的命令

首先说下,md5到底是啥,它是一段固定长度的数据。无论原始数据是多长或多短,其MD5值都是128bit。另外md5是确定性,一个原始数据的MD5值是唯一的,同一个原始数据不可能会计算出多个不同的MD5值;类似人类的身份…

iOS - UISearchController

前言 NS_CLASS_DEPRECATED_IOS(3_0, 8_0, "UISearchDisplayController has been replaced with UISearchController")interface UISearchDisplayController : NSObjectavailable(iOS, introduced3.0, deprecated8.0, message"UISearchDisplayController has bee…

浮点数转换为整数四舍五入_定义宏以将浮点值四舍五入为C中最接近的整数

浮点数转换为整数四舍五入Given a float value and we have to round the value to the nearest integer with the help of Macro in C language. 给定一个浮点值,我们必须借助C语言中的Macro将其舍入到最接近的整数。 Macro Definition: 宏定义: #def…

c语言遍历文件内容_C语言学习第28篇---动态内存分配剖析

为什么C语言要动态分配内存的意义?1.C语言中的一切操作都是基于内存的2.变量和数组都是内存的别名---内存分配由编译器在编译期间决定的---定义数组的时候必须指定数组长度---数组长度是在编译期就必须确定的需求:程序运行的过程中,可能需要使…

重启mysql的命令 linux_linux重启mysql命令

如何启动/停止/重启MySQL一、 启动方式1、使用 service 启动:service mysqld start2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start3、使用 safe_mysqld 启动:safe_mysqld&二、停止1、使用 service 启动:service mysqld s…

tomcat 多项目多HOST配置

一、场景&#xff1a;使用一个tomcat部署多个项目&#xff0c;并且分别使用不同域名进行访问。二、详细配置tomcat/conf/server.xml 中写<Engine name"Catalina" defaultHost"localhost">***********************************<Host name"biz…

javascript原型_使用JavaScript的示例报告卡Web应用程序原型

javascript原型Hi! At times, beginners always find it hard getting the application of the theory they learn In programming or a particular language. 嗨&#xff01; 有时&#xff0c;初学者总是很​​难在编程或特定语言中应用他们学到的理论。 In this article, we…

vb.net cad 块表最后的实体_21个绘图命令+7个技巧,3分钟让你成为CAD高手

绘制图纸需要用到CAD&#xff0c;CAD制图在生活中也是广泛运用&#xff0c;那么学习CAD到底难不难呢&#xff1f;在这里要告诉CAD新手们&#xff0c;世上无难事&#xff0c;可以用3分钟让你成为CAD高手。21个绘图命令A&#xff1a;绘圆弧B&#xff1a;定义块C&#xff1a;画圆D…

本地tomcat启动war包_「shell脚本」懒人运维之自动升级tomcat应用(war包)

准备&#xff1a;提前修改war包里的相关配置&#xff0c;并上传到服务器&#xff1b;根据要自动升级的tomcat应用修改或添加脚本相关内容&#xff1b;tomcat启动脚本如是自己写的&#xff0c;要统一格式命名&#xff0c;如&#xff1a;xxx、xxxTomcat 等&#xff1b;拿到生产使…

python将txt转为字符串_python做第一只小爬虫

“受尽苦难而不厌&#xff0c;此乃修罗之路”本文技术含量过低&#xff0c;请谨慎观看之前用R语言的Rcurl包做过爬虫&#xff0c;给自己的第一感觉是比较费劲&#xff0c;看着看着发际线就愈加亮眼&#xff0c;最后果断丢之。不过好的是和python爬取原理基本一致&#xff0c;且…

c#查找列表指定元素的索引_在集合的指定索引处插入元素 在C#中

c#查找列表指定元素的索引Given a Collection<T> of Integer and we have to insert an element at given index. 给定Integer的Collection <T>&#xff0c;我们必须在给定的索引处插入一个元素。 To insert an element in Collection<T>, we use Insert() …

跨域技术(JSONP与CROS)

JSONP 我们发现&#xff0c;Web页面上调用js文件时不受是否跨域的影响&#xff0c;凡是拥有"src"这个属性的标签都拥有跨域的能力&#xff0c;比如<script>、<img>、<iframe>。那就是说如果要跨域访问数据&#xff0c;就服务端只能把数据放在js格式…