【C++】List 基本接口的使用

news2024/10/2 3:34:43

LIST

  • List 基本接口介绍
    • 前言
    • list 构造方法
    • list 析构方法
    • 容量相关
    • 元素获取
    • 迭代器
    • 元素的修改
    • 其他相关操作

前边博客中已经介绍了c++ STL 中的 string 以及 vector 基本接口的使用方法并进行了接口的模拟实现,接下来让我们来学习 list 的基本接口使用方法吧~~

List 基本接口介绍

前言

List 是一个带头结点的双向循环链表,已知头节点 _head 可以找到它的前驱节点(尾节点)以及后继节点(首节点–第一个节点),但是寻找中间的某个节点信息时候就需要从 _head 位置开始进行遍历:

在这里插入图片描述

list 构造方法

本博客介绍的是 C++98 下的构造方法:
在这里插入图片描述

(1)构造一个空链表

list (const allocator_type& alloc = allocator_type());

(2)构造有 n 个值为 val 的链表

list (size_type n, const value_type& val = value_type(),
const allocator_type& alloc = allocator_type());

(3)区间构造方法

template < class InputIterator >
list (InputIterator first, InputIterator last,
const allocator_type& alloc = allocator_type());

(4)拷贝构造

list (const list& x);

为了便于后续的接口测试,我们来自定义一个打印函数:

template<class T>
void PrintMyList(const list<T>& L)
{
	for (auto e : L)
		cout << e << " ";
	cout << endl;
}

接下来看看如何进行使用这些构造接口:

void my_test0()
{
	list<int> L1;
	list<int> L2(5, 3);

	vector<int> v{ 1,2,3,4,5,6,7,8 };
	list<int> L3(v.begin(), v.end());

	list<int> L4(L3);
}

在这里插入图片描述

list 析构方法

在这里插入图片描述
在使用库中的接口信息,链表使用结束是会自动进行销毁操作的。

容量相关

在这里插入图片描述

在这里插入图片描述

元素获取

在这里插入图片描述
在这里插入图片描述

迭代器

在这里插入图片描述

(1)正向迭代器

回顾在 vector 中,我们提到迭代器是为了便于获取容器中间的所有元素,因此在正向迭代器中 begin() 指向的是第一个元素的位置,end() 指向的是最后一个有效元素的下一个空间的位置

而在 list 当中,由于 list 是带头双向循环链表,因此将 begin() 设在首节点的位置 ,end() 设在最后一个有效元素的下一个空间的位置,也就是头节点的位置:

在这里插入图片描述

(2)反向迭代器

与正向迭代器刚好相反:

反向迭代器
我们来测试一下遍历 list 链表:

在这里插入图片描述

元素的修改

在这里插入图片描述

(1)尾插尾删、头插头删接口测试

在这里插入图片描述

(2)任意位置插入接口测试

insert

在 pos 位置插入单个值为 val 的元素:

iterator insert (iterator position, const value_type& val);

1)insert 在第一个元素之前插入新元素:

在这里插入图片描述

从图中我们可以看出在链表的头部插入元素可以成功,并且打印链表信息也是可以的

回顾

在 vector 容器中我们提到了“迭代器失效”,是指由于插入元素或是删除元素导致容器底层空间发生变化而导致迭代器所指向的位置失效,那么在 list 中是否也会发生迭代器失效呢?我们可以打印迭代器所指向位置的元素来试试看:

在这里插入图片描述
从打印信息来看,在 pos 位置之前插入新的元素时,并未发生迭代器的失效

2)insert 在尾部插入新元素:

在这里插入图片描述

3)insert 在指定元素之前插入新元素:

在这里插入图片描述

在此段代码中我们使用到了查找算法,需要对 list 链表进行从头开始的遍历:

	int val=4;   //要进行查找的元素
	auto pos = L1.begin();
	while (pos != L1.end())
	{
		if (*pos == val)   //找到该元素位置
			break;
		++pos;
	}

假如代码中存在多处的查找操作,采用普通的遍历操作会使得代码效率极大地降低,并且会造成代码的冗余,因此在 C++ 库中给我们提供了一个全局的查找接口 find,可以在 vector 容器或是 list 链表中进行查找操作:

template <class InputIterator, class T>
InputIterator find (InputIterator first, InputIterator last, const T& val);

因此上述查找我们直接可以使用一行代码来进行替换:

auto pos = find(L1.begin(), L1.end(), 4);

在这里插入图片描述

在 pos 位置插入 n 个值为 val 的元素:

void insert (iterator position, size_type n, const value_type& val);

在这里插入图片描述

在 pos 位置插入某个给定区间中的元素

template < class InputIterator>
void insert (iterator position, InputIterator first, InputIterator last);

在这里插入图片描述

(3)在任意位置删除接口测试

删除某个位置元素:

iterator erase (iterator position);

在这里插入图片描述
可以发现,删除元素时候导致了删除位置的迭代器失效了,但是后续的元素可以正常进行打印,在上一篇博客中我们指导在 vector 容器中插入或删除元素都会导致迭代器失效,并且操作(插入或删除)之后不能够获取到后续元素,而 list 只有在删除元素时候会导致迭代器的失效

为防止发生迭代器失效,我们需要将删除之后的元素位置进行返回即可避免:

在这里插入图片描述

删除区间中元素:

iterator erase (iterator first, iterator last);

在这里插入图片描述

(4)swap 交换接口测试

	list<int> L1{ 1,2,3,4,5,6 };
	list<int> L2{ 9,8,7,6,5 };
	L1.swap(L2);

在这里插入图片描述

(5)resize 接口测试

resize 修改有效元素个数,多余空间使用 val 来进行填充:

void resize (size_type n, value_type val = value_type());

在这里插入图片描述

(6)clear 接口测试

清空所有有效元素:

在这里插入图片描述

其他相关操作

在这里插入图片描述

(1)remove 移除所有值为 val 的元素

void remove (const value_type& val);

在这里插入图片描述

(2)remove_if 移除满足条件的元素

template < class Predicate>
void remove_if (Predicate pred);

在这里插入图片描述

(3)sort 对 list 中元素进行排序

sort 默认是按照升序进行排序的:
在这里插入图片描述

若想要指定排序方式,我们可以自定义一个函数:

//定义排序方式函数
bool My_Compare(int left, int right)
{
	//return left < right;   // 小于方式---------升序排序
	return left > right;   //大于方式----------降序排序
}

在这里插入图片描述

(4)merge 合并两个链表

默认方式进行合并

void merge (list& x);

在这里插入图片描述

当我们调用 merge 接口时候发现触发了异常,这主要是因为编译器不知道以何种方式对这两个链表进行合并,因此在进行链表合并操作之前我们要先对链表进行一个排序的操作

在这里插入图片描述

自定义合并链表的方式(降序为例)

template < class Compare>
void merge (list& x, Compare comp);

//定义排序方式函数
bool My_Compare(int left, int right)
{
	//return left < right;   // 小于方式---------升序排序
	return left > right;   //大于方式----------降序排序
}

在这里插入图片描述

(5)reverse 链表的逆置

直接调用接口即可:
在这里插入图片描述

有关于 list 库中接口的测试就到这里啦,小伙伴们一定要自己动手来测一测才能理解得更加深刻哦!

下一节我们来介绍有关于 list 相关接口的模拟实现哈!(提示:注意理解迭代器的使用内涵**)

敲黑板

多练多理解,多试错多调试才能够进步,加油吧!

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

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

相关文章

Linux基础命令-stat显示文件的状态信息

文章目录 stat 命令介绍 语法格式 基本参数 测试三个时间的变化过程 1&#xff09;使用cat命令 2&#xff09;使用echo命令 3&#xff09;使用chmod命令 4&#xff09;使用vim命令 参考实例 1&#xff09;显示文件的状态信息 2&#xff09;以简洁的形式显示状态信…

Android:IdleHandler的简单理解和使用

IdleHandler的简单理解和使用1、IdleHandler 是什么2、IdleHandler 使用方式2.1、添加和删除2.2、执行3、常见问题和使用场景3.1、使用场景3.2、常见问题参考1、IdleHandler 是什么 IdleHandler 说白了&#xff0c;就是 Handler 机制提供的一种&#xff0c;可以在 Looper 事件…

Cesium 100K数据加载 支持弹窗 动态更改位置

前言&#xff1a;今天总结关于point、label、billboard海量数据加载。后续会研究下大量model加载以及大bim(几百G上T)模型记载 海量点加载 弹窗 加载点位时&#xff0c;不加载弹窗。点击点位时在加载弹窗&#xff0c;及有效的减少加载量&#xff0c;优化性能。 const handler …

FPGA学习之日常工作复位电路

最近一个多月没有写博客了&#xff0c;然后最近工作中也遇到一个复位信号的问题。问题是这样的&#xff0c;关于外部复位信号&#xff0c;之前我们的处理方式都是通过PLL产生的Lock信号作为内部的复位信号。但是由于换到A54上面没有IP核&#xff0c;所以只有不用PLL&#xff0c…

Mybatis持久层框架 | 动态SQL、缓存

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; 动态SQL 动态SQL就是指根据不同条件生成不同的sql语句&#xff0c;本质还是SQL语句&#xff0c;知识可以在SQL层面&#xff0c;执行逻辑代码 搭建环境 创建数据库 cre…

Linux搭建SVN服务器,并内网穿透实现公网远程访问

文章目录1. Ubuntu安装SVN服务2. 修改配置文件2.1 修改svnserve.conf文件2.2 修改passwd文件2.3 修改authz文件3. 启动svn服务4. 内网穿透4.1 安装cpolar内网穿透4.2 创建隧道映射本地端口5. 测试公网访问6. 配置固定公网TCP端口地址6.1 保留一个固定的公网TCP端口地址6.2 配置…

HCIA-HarmonyOS Application Developer——题目集2

题目1 1、HarmonyOS的"18N”战略中的"1"指的是什么? A、智慧屏 B、平板电脑 C、手表 D、手机 解析&#xff1a;&#xff08;D&#xff09; HarmonyOS是一款面向万物互联时代的、全新的分布式操作系统&#xff0c;是一个全场景分布式智慧操作系统&#xff0c;覆…

从产品经理的角度如何提升项目的交付质量?

提高交付质量 &#xff0c;对于每个IT公司都是永恒的话题。 交付质量其实包含2重意义&#xff0c; 一是交付的高质量&#xff08;客户角度&#xff09;&#xff0c;即客户的满意度&#xff1b;二是高质量的交付&#xff08;交付团队的角度&#xff09;&#xff0c;这里是指如何…

【笔记】ChatGPT是怎样炼成的(李宏毅2023机器学习课程引入部分)

来源&#xff1a;【授权】李宏毅2023春机器学习课程 ChatGPT太火热了&#xff0c;借此简单了解一下 ChatGPT的newbie之处在哪里&#xff1f; 同一个问题&#xff0c;它的每次回答都不同&#xff1b;处于同一个chat中&#xff0c;我可以追问多个问题&#xff0c;因为它知道上下…

NO.8代码随想录第8天-字符串|●28. 实现 strStr()●459.重复的子字符串●字符串总结

KMP算法的原理&#xff1a; KMP算法&#xff1a;解决字符串匹配的问题。 前缀&#xff1a;包含首字母不包含尾字母的所有子串。 后缀&#xff1a;包含尾字母不包含首字母的所有子串。 最长相等前后缀&#xff1a;以模式串aabaaf为例&#xff0c;这里从a开始到aabaaf&#x…

数据结构入门DAY1

力扣刷题合集&#xff1a;力扣刷题_Sunlightʊə的博客-CSDN博客217.存在重复元素相关题目链接&#xff1a;力扣 - 存在重复元素题目重现给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 &#xff0c;返回 true &#xff1b;如果数组中每个元素互不相同&#xff0c;返…

【Spark分布式内存计算框架——Spark Streaming】5. DStream(上)

3. DStream SparkStreaming模块将流式数据封装的数据结构&#xff1a;DStream&#xff08;Discretized Stream&#xff0c;离散化数据流&#xff0c;连续不断的数据流&#xff09;&#xff0c;代表持续性的数据流和经过各种Spark算子操作后的结果数据流。 3.1 DStream 是什么…

镜像、复制和直线绘制CAD图形

这个CAD图形可以分成两个部分&#xff1a;上面一部分和下面一部分&#xff0c;都是有多个相同的对象&#xff0c;所以只需要绘制出其中一个再使用复制和旋转命令将其它的绘制出就可了&#xff0c;用到的主要CAD命令有CAD直线、CAD旋转、CAD镜像和CAD直线 目标对象 操作步骤 1…

利用递归实现括号匹配

案例引入以下则是各个字符串经过括号处理之后的结果&#xff1a;12((21))(12-->12(21)1232((((2121)212(21)-->32(2121)212(21)ABDF((SA)SA)SA(SA)SA(((-->ABDF((SA)SA)SA(SA)SA算法思路&#xff1a;这个问题的解决方法就是将字符按顺序逐一加入到新的string容器store…

python自学之《21天学通Python》(14)——第17章 Web网站编程

Web编程是程序设计应用之一&#xff0c;随着动态网站不断发展&#xff0c;Web编程已经成为程序设计的重要应用领域。目前Web编程主要有ASP.NET、PHP、Java等编程语言&#xff0c;Python语言也可以像其他语言一样应用于Web服务。 17.1 Web网站编程概述 Web是一个由许多互相链接…

mysql索引分析之二

mysql索引分析之一 mysql索引分析之二 mysql索引分析之二1 mysql的索引类型2 Explain执行计划2.1 执行计划之 id 属性2.1.1 id 的属性相同表示加载表的顺序是从上到下2.1.2 id 值越大&#xff0c;优先级越高2.1.3 id 有相同&#xff0c;也有不同&#xff0c;同时存在2.2 执行计…

浅析 Redis 主从同步与故障转移原理

我们在生产中使用 Redis&#xff0c;如果只部署一个 Redis 实例&#xff0c;当该实例宕机&#xff0c;到恢复之前都不可用&#xff1b;虽说 Redis 一般都用来做缓存&#xff0c;但不可用给业务系统带来的影响也是不小的&#xff0c;流量大时甚至会导致整个服务宕机。所以 Redis…

6.0.4:GrapeCity Documents for Excel GcExcel Crack

在更短的时间内生成 Excel 电子表格&#xff0c;不依赖于 Excel&#xff01; 在任何应用程序中转换、计算、格式化和解析电子表格。 快速高效&#xff1a;其轻巧的尺寸意味着 Documents for Excel 针对快速处理大型 Excel 文档进行了优化 使用适用于 Windows、Linux 和 Mac 的…

Spring Cloud Sentinel实战(一)- Sentinel介绍

Sentinel介绍 什么是Sentinel 分布式系统的流量防卫兵&#xff1a;随着微服务的普及&#xff0c;服务调用的稳定性变得越来越重要。Sentinel以“流量”为切入点&#xff0c;在流量控制、断路、负载保护等多个领域开展工作&#xff0c;保障服务可靠性。 特点&#xff1a; 1. 2…

【尚硅谷MySQL入门到高级-宋红康】数据库概述

1、为什么要使用数据库 数据的持久化 2、数据库与数据库管理系统 2.1 数据库的相关概念 2.2 数据库与数据库管理系统的关系 3、 MySQL介绍 MySQL从5.7版本直接跳跃发布了8.0版本 &#xff0c;可见这是一个令人兴奋的里程碑版本。MySQL 8版本在功能上做了显著的改进与增强&a…