数据结构之顺序表

首先我们回忆一下逻辑结构的分类,有线性结构,树形结构以及图形结构,线性结构中不受限制的线性表用顺序存储的存储方式存储就是顺序表,顺序表可以代表一个完整的顺序表。

首先研究一下逻辑结构:线性表,有三个主要的特点(所有数据元素的数据类型都相同,有限个,序列)

存储结构:顺序存储,可以静态实现也可以动态实现

基本操作:创建销毁,增删查改

从这里开始细致讲解一下静态存储和动态存储的区别:

程序开始,首先定义数据元素,重命名为elemtype,这样不论是结构体还是原子类型的数据类型都可以用它来表示,程序更容易读懂,然后开始创建顺序表,如果是静态实现,则结构体中有一个数据元素类型的数组以及一个num变量用来记录目前存入了多少个数据元素,然后在主函数中创建这个结构体就等于创建完了这个数据结构。

若是动态实现,创建结构体时我们需要改一下,结构内部没有数组,有一个指向数据元素类型的指针,用来接收malloc得到的首元素指针,而且后面若空间不够需要扩大,则使用realloc或者malloc都可以实现。

在实际操作中,增我们要注意是否已经满了,插入的位置是否正确,并且要找准向后移动哪些元素

删除的时候要判断是否空了,还要判断是否位置合法

其他操作比较简单。

有几个比较经典的习题:

1、删除符合某种条件的数字:有三种思路

第一种就是最普通的删除,遍历这个数组的时候碰到需要删除的数字,将后面所有的向前移即可,时间复杂度n的平方

第二种是是空间换时间,创建一个新数组,将不需要删除即不满足删除条件的数据移到这个新的数组中,这段空间是用来辅助的,因此空间复杂度为n,时间复杂度为n

第三种是双指针法,一个指针用来遍历所有元素,另一个指针用来指向合法存储的空间

2、两个数组的合并

第一种是创建一个新的数组,双指针法分别遍历两个数组,最后将没有遍历完的数组移到新数组即可

第二种,若不额外开创空间,我们需要保证有一个数组的空间是足够装开这两个数组的,然后从最后开始填充,先找最大的放到最后,直至有一个数组遍历到头,然后将另一个数组中的元素依次挪进去即可

冒泡排序、逆序、二分查找、空间辅助这几个方法非常重要

顺序表的优点:从存储结构来看,存储密度高,从操作看,支持随机存取

缺点:从存储结构看,无法扩充空间或扩充空间时间复杂度高,从操作上看,插入删除的时间复杂度很高

相关推荐
田梓燊11 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
葳_人生_蕤11 小时前
hot100——栈和队列
数据结构
Meme Buoy14 小时前
18.补充数学1:生成树-最短路径-最大流量-线性规划
数据结构·算法
汀、人工智能14 小时前
[特殊字符] 第89课:岛屿数量
数据结构·算法·数据库架构·图论·bfs·岛屿数量
九英里路14 小时前
cpp容器——string模拟实现
java·前端·数据结构·c++·算法·容器·字符串
2401_8920709814 小时前
顺序栈(动态数组实现) 超详细解析(C++ 语言 + 可直接运行)
数据结构·c++·顺序栈
漫霂15 小时前
二叉树的翻转
java·数据结构·算法
3秒一个大15 小时前
深入理解 JS 中的栈与堆:从内存模型到数据结构,再谈内存泄漏
前端·javascript·数据结构
旖-旎15 小时前
哈希表(存在重复元素)(3)
数据结构·c++·学习·算法·leetcode·散列表
计算机安禾15 小时前
【数据结构与算法】第39篇:图论(三):最小生成树——Prim算法与Kruskal算法
开发语言·数据结构·c++·算法·排序算法·图论·visual studio code