C++超详细分析顺序表

 更新时间:2022年03月24日 11:03:56   作者:程序猿教你打篮球  
程序中经常需要将一组数据元素作为整体管理和使用,需要创建这种元素组,用变量记录它们,传进传出函数等。一组数据中包含的元素个数可能发生变化,顺序表则是将元素顺序地存放在一块连续的存储区里,元素间的顺序关系由它们的存储顺序自然表示

本次我们解剖顺序表将从以下三个结构:

1、静态顺序表和动态顺序表

2、顺序表实现增删查改等常见接口

3、顺序表相关OJ题练习

什么是顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存 储。在数组上完成数据的增删查改。

兄弟们兄弟们,记得抠字眼啊,顺序表一定是连续的存储单元,并且是依次存储数据的!!!!

顺序表一般可以分为:

⛳ 静态顺序表      🏀 动态顺序表

静态顺序表:使用定长数组存储,简单来说大小是固定的,数据个数也是固定的!

动态顺序表:使用动态开辟的数组存储,简单来说,装满了会自动扩大容量!

静态顺序表的实现我们就不讲了,冬天到了春天还会远吗?会了动态你还不会静态吗?所以我们今天主要讲动态顺序表!静态顺序表搭建代码如下:

// 顺序表的静态存储
#define N 100
typedef int SLDataType;
typedef struct SeqList
{
    SLDataType array[N]; // 定长数组
    size_t size;     // 有效数据的个数 
}SeqList;

动态顺序表

🏀 来到今天的重点!动态顺序表!

首先先来搭建顺序表的结构。

🎉 上面就是我给大家画的基本一个结构图了,下面我们来实现顺序表的基本接口:

💛 首先我们顺序表需要初始化:

 🧡 既然我们没有在初始化给定大小,我们现在要判断需不需要给动态表顺序表增容:

 🔺 我们来实现动态顺序表头部插入数据:

 🔻 接着来实现尾部插入数据:

 🌛 我们要开始实现头部删除数据了:

🌞 下面实现尾部删除数据:

 🌈 接着我们来实现在pos下标位置插入数据:

 🚩 我们再来实现删除pos下标位置的数据:

⛅ 查找顺序表中的元素x:

 🚀 修改指定pos下标的数据

在实际中在我上面写的函数有些都可以复用哦!这个就等着你们去发现吧,我们接着往下走:

其实还有一些顺序表的打印,清空,求元素个数,这些相信你们看完上面的内容对于你们来说非常容易!我就不一一举例了,下面进入我们的习题时间!(●'◡'●)

题目1:给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,并返回移除后数组的新长度。不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并原地修改输入数组。元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

示例 1:

输入:nums = [0,1,2,2,3,0,4,2], val = 2

输出:5, nums = [0,1,4,0,3]

解释:函数应该返回新的长度 5, 并且 nums 中的前五个元素为 0, 1, 3, 0, 4。注意这五个元素可为任意顺序。你不需要考虑数组中超出新长度后面的元素。

题目来源:27. 移除元素 - 力扣(LeetCode) (leetcode-cn.com)

思路1:遍历数组,发现元素为val就把后面的往前挪覆盖掉val,但是这样的时间复杂度为O(N²),这样当数组全是val,效率就会特别低!

思路2:以空间换时间,开辟一个新数组,把不是val的数放到新数组,再把新数组的值拷贝回来!但是这样的话空间复杂度O(N)不符合题意!

思路3:使用双指针,空间复杂度O(1),时间复杂度O(n),代码如下:

int removeElement(int* nums, int numsSize, int val)
{
	int src = 0;
	int dst = 0;
	while (src < numsSize)
	{
		if (nums[src] != val)
		{
			nums[dst++] = nums[src++];
		}
		else
		{
			++src;
		}
	}
	return dst;
}

题目2:给你两个按非递减顺序排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。请你 合并 nums2 到 nums1 中,使合并后的数组同样按非递减顺序排列。

示例 1:

输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3

输出:[1,2,2,3,5,6]

解释:需要合并 [1,2,3] 和 [2,5,6] 。

合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。

题目来源:88. 合并两个有序数组 - 力扣(LeetCode) (leetcode-cn.com)

 那这道题的思路就留给小伙伴们自己去思考了,我就直接给你们上代码!

void merge(int* nums1, int m, int* nums2, int n)
{
	int end1 = m - 1;
	int end2 = n - 1;
	int end = m + n - 1;
	while (end1 >= 0 && end2 >= 0)
	{
		if (nums1[end1] > nums2[end2])
		{
			nums1[end] = nums1[end1];
			--end;
			--end1;
		}
		else
		{
			nums1[end] = nums2[end2];
			--end;
			--end2;
		}
	}
	//如果是end2结束,不需要处理因为就是在nums1里面
	while (end2 >= 0)
	{
		nums1[end] = nums2[end2];
		--end;
		--end2;
	}
}

好了,通过这篇文章的学习,相信你会把顺序表理解的更透彻,还是那句话,我们一起快乐编程不头秃!加油奥里给!👻👻👻

🌸🌸🌸🌸🌸🌸完结撒花!🌸🌸🌸🌸🌸🌸

gitee(码云):Mercury. (zzwlwp) - Gitee.com

到此这篇关于C++超详细分析顺序表的文章就介绍到这了,更多相关C++ 顺序表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言 浅谈栈与队列的定义与操作

    C语言 浅谈栈与队列的定义与操作

    栈和队列,严格意义上来说,也属于线性表,因为它们也都用于存储逻辑关系为 "一对一" 的数据,但由于它们比较特殊,因此将其单独作为一章,做重点讲解
    2021-11-11
  • C++容器适配器的概念与示例

    C++容器适配器的概念与示例

    C++ STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量、链表、队列、栈,今天我们来探究一下stl容器适配器的使用吧
    2023-01-01
  • C++ CopyFile,MoveFile用法案例详解

    C++ CopyFile,MoveFile用法案例详解

    这篇文章主要介绍了C++ CopyFile,MoveFile用法案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码

    C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码

    这篇文章主要介绍了C++ 中实现把EXCEL的数据导入数据库(ACCESS、MSSQL等)实例代码的相关资料,需要的朋友可以参考下
    2017-04-04
  • 如何在 C++ 中实现一个单例类模板

    如何在 C++ 中实现一个单例类模板

    这篇文章主要介绍了如何在 C++ 中实现一个单例类模板,帮助大家更好的理解和学习c++编程,感兴趣的朋友可以了解下
    2020-10-10
  • C++的std::vector<bool>转储文件问题

    C++的std::vector<bool>转储文件问题

    这篇文章主要介绍了C++的std::vector<bool>转储文件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++实现有向图的邻接表表示

    C++实现有向图的邻接表表示

    这篇文章主要为大家详细介绍了C++实现有向图的邻接表表示,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • C语言详解如何实现顺序栈

    C语言详解如何实现顺序栈

    顺序栈,就是用一组地址连续的存储单元来存放栈元素,然后用一个栈结构去维护一个栈。在C中,可用动态开辟的数组去表示,维护的栈结构需要有一个栈底和一个栈顶指针
    2022-04-04
  • C++中对象的赋值与复制操作详细解析

    C++中对象的赋值与复制操作详细解析

    对象之间的赋值也是通过赋值运算符“=”进行的。本来赋值运算符“=”只能用来对单个的变量赋值,现在被扩展为两个同类对象之间的赋值,这是通过对赋值运算符的重载实现的
    2013-10-10
  • C语言函数调用的三种实现方法实例

    C语言函数调用的三种实现方法实例

    C语言中函数的调用主要有如下三种方法,直接调用,函数指针调用,函数指针传递调用其中后两种本质一样,但在有无返回值时还稍有差别,下面这篇文章主要给大家介绍了关于C语言函数调用的三种实现方法,需要的朋友可以参考下
    2022-01-01

最新评论