【C++初阶】list的使用

news2024/11/18 17:31:07

大家好我是沐曦希💕

文章目录

  • 一、前言
  • 二、构造
  • 三、迭代器
  • 四、增删查改
    • 1.头插头删
    • 2.尾插尾删
    • 3.查找和插入
    • 4.删除
  • 五、其他成员函数
    • 1.排序和去重
    • 2.splice和remove
    • 3.resize

一、前言

list本质是带头双向循环链表,本文只对list的一些常用接口进行说明,对于其他一些接口可自行查看文档C++ Reference
在这里插入图片描述
在这里插入图片描述

二、构造

在这里插入图片描述

构造函数( (constructor))接口说明
list (size_type n, const value_type& val = value_type())构造的list中包含n个值为val的元素
list()构造空的list
list (const list& x)拷贝构造函数
list (InputIterator first, InputIterator last)用[first, last)区间中的元素构造list
void testlist1()
{
	list<int> lt1; // 无参构造
	list<int> lt2(5, 1); // n个val构造
	list<int> lt3(lt2.begin(), lt2.end()); // 迭代器区间构造
	list<int> lt4(lt3); // 拷贝构造
}

在这里插入图片描述

三、迭代器

在这里插入图片描述

函数声明接口说明
begin + end返回第一个元素的迭代器+返回最后一个元素下一个位置的迭代器
rbegin +rend返回第一个元素的reverse_iterator,即end位置,返回最后一个元素下一个位置的reverse_iterator,即begin位置

在这里插入图片描述

void testlist2()
{
	//正向迭代器
	list<int> lt1;
	lt1.push_back(1);
	lt1.push_back(2);
	lt1.push_back(3);
	lt1.push_back(4);
	list<int>::iterator it = lt1.begin();
	while (it != lt1.end())
	{
		cout << *it << " ";
		++it;
	}
	cout << endl;
}

在这里插入图片描述

void testlist2()
{
	list<int> lt1;
	lt1.push_back(1);
	lt1.push_back(2);
	lt1.push_back(3);
	lt1.push_back(4);
	list<int>::reverse_iterator rit = lt1.rbegin();
	while (rit != lt1.rend())
	{
		cout << *rit << " ";
		++rit;
	}
	cout << endl;
}

在这里插入图片描述

注意:

1. begin与end为正向迭代器,对迭代器执行++操作,迭代器向后移动

2. rbegin(end)与rend(begin)为反向迭代器,对迭代器执行++操作,迭代器向前移动

四、增删查改

1.头插头删

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

void testlist3()
{
	list<int> lt;
	lt.push_front(1);
	lt.push_front(2);
	lt.push_front(3);
	lt.push_front(4);
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
	lt.pop_front();
	lt.pop_front();
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

2.尾插尾删

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

void testlist4()
{
	list<int> lt;
	lt.push_back(1);
	lt.push_back(2);
	lt.push_back(3);
	lt.push_back(4);
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
	lt.pop_back();
	lt.pop_back();
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

3.查找和插入

在list容器中没有提供find函数,可以通过算法库提供find进行查找

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

在这里插入图片描述

find和insert可以相互配合使用。

在这里插入图片描述

1.通过find找到位置插入
2.找到位置后插入n个val的值
3.找到位置后插入迭代器的区间

void testlist5()
{
	list<int> lt;
	lt.push_back(1);
	lt.push_back(2);
	lt.push_back(3);
	lt.push_back(4);
	auto pos = find(lt.begin(), lt.end(), 3);
	// 1.在pos之前插入一个值
	if (pos != lt.end())
		lt.insert(pos, 30); //insert以后pos没有失效
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
	cout << *pos << endl;
	// 2.插入n个数据
	pos = find(lt.begin(), lt.end(), 3);
	if (pos != lt.end())
		lt.insert(pos, 4, 10);
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
	// 3.插入一个迭代器区间
	vector<int> v(5, 20);
	pos = find(lt.begin(), lt.end(), 10);
	if (pos != lt.end())
		lt.insert(pos, v.begin(), v.end());
	for (const auto& e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

4.删除

在这里插入图片描述

void testlist6()
{
	list<int> lt;
	lt.push_back(1);
	lt.push_back(2);
	lt.push_back(3);
	lt.push_back(4);
	auto pos = find(lt.begin(), lt.end(), 3);
	if (pos != lt.end())
		lt.erase(pos);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	pos = find(lt.begin(), lt.end(), 4);
	if (pos != lt.end())
		lt.erase(pos, lt.end());
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

注意:对于list的insert的pos位置不会失效,在这个地方,只是在pos位置前增加节点,改变链接,pos位置并不会变成野指针。

五、其他成员函数

1.排序和去重

  • sort

算法库有一个sort函数,但是list自己实现了,因为算法库的sort不能排序list:

算法库里的sort对于物理空间是连续的,只有vector和string能够使用,而对于list来说,物理空间并不是连续的,并不适用,所以list自己提供了一个sort进行排序,此外,链表的排序是归并排序。

在这里插入图片描述

void testlist7()
{
	list<int> lt;
	lt.push_back(12);
	lt.push_back(1);
	lt.push_back(6);
	lt.push_back(9);
	lt.push_back(4);
	lt.push_back(8);
	lt.push_back(10);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	lt.sort();
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

  • unique

对于unique:用来删除链表中连续的重复元素,但是注意:一定是要先排完序在进行删除,如果没有进行排序:而直接进行去重的话,会导致去重去不完全
在这里插入图片描述

void testlist8()
{
	list<int> lt;
	lt.push_back(12);
	lt.push_back(9);
	lt.push_back(1);
	lt.push_back(12);
	lt.push_back(12);
	lt.push_back(9);
	lt.push_back(8);
	lt.push_back(9);
	lt.push_back(12);
	lt.unique();
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	lt.sort();
	lt.unique();
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

2.splice和remove

  • splice

在这里插入图片描述

void testlist9()
{
	//转移到某个位置
	list<int> lt1(5, 10);
	list<int> lt2(4, 7);
	lt1.splice(lt1.begin(), lt2);
	for (auto e : lt1)
		cout << e << " ";
	cout << endl;
	
	//从某个位置转移
	list<int> lt3(4, 10);
	list<int> lt4(4, 5);
	lt3.splice(lt3.begin(), lt4, lt4.begin());
	for (auto e : lt3)
		cout << e << " ";
	cout << endl;

	//迭代器区间转移
	list<int>lt5(3, 10);
	list<int>lt6(3, 20);
	lt5.splice(lt5.begin(), lt6, lt6.begin(), lt6.end());
	for (auto e : lt5)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

  • remove

在这里插入图片描述
remove可以直接删除list中指定的数据

void testlist10()
{
	list<int> lt;
	lt.push_back(1);
	lt.push_back(2);
	lt.push_back(3);
	lt.push_back(4);
	lt.push_back(1);
	lt.push_back(1);
	lt.remove(3);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	lt.remove(1);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

3.resize

在这里插入图片描述
list的resize很少用

void testlist11()
{
	list<int> lt(5, 10);
	lt.resize(3);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	lt.resize(5);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
	lt.resize(7, 10);
	for (auto e : lt)
		cout << e << " ";
	cout << endl;
}

在这里插入图片描述

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

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

相关文章

Qt creator中操作QAction加入QToolBar

背景&#xff1a;个人笔记。我之前没有系统化学习过任何资料&#xff0c;使用很多工具都是按需出发&#xff0c;直接上手&#xff0c;遇到问题再研究的。所以会有一些弯路。本文言语中难免有对个人情绪的生动描述&#xff0c;希望不要影响读者心情&#xff0c;这只是我学习过程…

前端网络安全

什么是同源策略同源指的是&#xff1a;协议、端口号、域名必须一致。他是浏览器的一个用于隔离潜在恶意文件的重要安全机制。限制了从同一个源加载的文档或脚本&#xff0c;与另一个源的资源进行交互。同源策略主要限制了三个方面&#xff1a;当前域下的js脚本不能够访问其他域…

waf和web应用防火墙的区别

waf和web应用防火墙有什么区别?相信这两个词大家都不陌生&#xff0c;特别是做互联网行业的小伙伴们。对于waf和web应用防火墙&#xff0c;这两个名词的理解应该都很清楚。但是很多小伙伴们不知道WAF防火墙与Web防火墙有什么区别&#xff0c;它们之间的区别在哪里&#xff0c;…

Spring Cloud(微服务)学习篇(七)

Spring Cloud(微服务)学习篇(七) 1.使用代码的方式实现流量限制规则 1.1 变更SentinelController类 1.1.1 加入的代码 //流控限制 (一个或多个资源限流), postConstruct注解的作用是保证项目一启动就会加载,// 一个rule就是一个规则PostConstructpublic void FlowRule(){Li…

【C++】string的成员函数、成员常量和非成员函数

目录 string 1. string的成员函数 1.1 构造、析构和赋值运算符重载 1.1.1 构造函数 1.1.2 析构函数 1.1.3 赋值运算符重载 1.2 迭代器 1.3 容量 1.4 元素访问 1.4.1 遍历方法 1.5 修改器 1.6 字符串操作 2. string的成员常量 3. string的非成员函数 string 以下…

javaEE 初阶 — 应用层中的 DNS 协议(域名解析系统)

文章目录什么是域名1. 如何建立 域名 与 IP 的对应关系2. 域名的分级什么是域名 域名也就是平常所说的网址&#xff0c;比如 www.baidu.com。 其实网络上的服务器要访问这个网址&#xff0c;需要的是 IP 地址。、 但是 IP 地址比较拗口不方便记忆&#xff0c;于是就有使用一些…

单向非循环链表

1、顺序表遗留问题 1. 中间/头部的插入删除&#xff0c;时间复杂度为O(N) 2. 增容需要申请新空间&#xff0c;使用malloc、realloc等函数拷贝数据&#xff0c;释放旧空间。会有不小的消耗。 3. 当我们以2倍速度增容时&#xff0c;势必会有一定的空间浪费。例如当前容量为100&a…

IDEA这些配置,简单高效

优化导包配置配置路径&#xff1a;File-> settings -> Editor -> General -> Auto ImportAdd unambiguous imports on the fly&#xff1a;自动导包Optimize imports on th fly (for current project)&#xff1a;自动删除无用包代码提示取消大小写配置路径&#x…

AOP(概念和原理)

文章目录1. AOP&#xff08;概念&#xff09;2. AOP&#xff08;底层原理&#xff09;2.1 AOP底层使用动态代理&#xff08;两种&#xff09;2.2 AOP 底层使用哪种代理方式 &#xff1f;3. AOP相关概念3.1 AOP术语4. AOP操作4.1 基于AspectJ实现AOP操作4.2 切点表达式4.3 基于A…

6 分布式事务简介

分布式事务简介 概念 基础概念&#xff1a;事务ACID * A&#xff08;Atomic&#xff09;&#xff1a;原子性&#xff0c;构成事务的所有操作&#xff0c;要么都执行完成&#xff0c;要么全部不执行&#xff0c;不可能出现部分成功部分失 败的情况。 * C&#xff08;Consisten…

嵌入式和Python(一):python环境搭建的详细步骤

目录 ● 安装python ① 更新软件列表 ② 安装编译python需要用到的环境 ③ 下载python源码 ④ 解压源码包 ⑤ 配置 ⑥ 编译 ⑦ 安装 ● 建立软连接 说明 ① 删除原来的软连接 ② 在/usr/bin/目录创建软连接python&#xff0c;定向/usr/local/bin/python3.9 ③ 检查…

Java面向对象:多态特性的学习

本文介绍了Java面向对象多态特性, 多态的介绍. 多态的实现条件–1.发生继承.2.发生重写(重写与重载的区别)3.向上转型与向下转型.4.静态绑定和动态绑定5. 实现多态 举例总结多态的优缺点 避免在构造方法内调用被重写的方法… Java面向对象:多态特性的学习一.什么是多态?二.多态…

MATLAB | 如何将colormap中心点置为0值处?

本期讲有一些绘图时正负部分需要分开赋予颜色&#xff0c;这时候双向colormap的中心对应的可能并不是数值0&#xff0c;该咋办&#xff0c;就比如下面的情况&#xff1a; 事先说明&#xff0c;为了绘图好看&#xff0c;本文中全部示例都在代码最后用了以下这个简单函数进行修饰…

库到底是个啥?为啥要链接,链接库的本质又是个啥?

目录 前言 一、库是个啥&#xff1f; ①最开始的库是用来解决啥问题&#xff1f; ②库的基本构成 ③动态库与静态库 二、如何生成库 0、相关知识 ①生成静态库 ②生成动态库 三、库的使用 ①修改环境变量 ②拷贝.so文件到系统共享库路径下, 一般指/usr/lib ③ldconfig 配置/etc…

安卓逆向_6 --- JNI 和 NDK

Java 本机接口规范内容&#xff1a;https://docs.oracle.com/en/java/javase/19/docs/specs/jni/index.html JNI官方中文资料&#xff1a;https://blog.csdn.net/yishifu/article/details/52180448 NDK 官方文档&#xff1a;https://developer.android.google.cn/training/ar…

【Python学习笔记】第二十八节 Python random 模块

一、Python random简介Python random 模块主要用于生成随机数。大部分python人都会用&#xff0c;但是一般人都是使用randint()帮我们生成某个范围的整数&#xff0c;但其实random模块还有很多非常使用的功能供我们使用&#xff0c;接下来我们就一一了解一下我们的random。要使…

JavaWeb系列之tomcat 服务器安装

文章目录一、JavaWeb应用程序架构B/S 架构C/S 架构B/S 与 C/S 对比MVC设计模式二、MVCMVC 开发项目搭建Web 服务器tomcat 服务器Idea 集成 tomcat第一个 JavaWeb 项目三、JSP 技术jsp 与 servlet 联系与区别一、JavaWeb 简介 JavaWeb 可以理解成使用 java 进行应用程序开发&am…

Windows-jdk8/jdk16安装

Windows-JAVA jdk-8安装教程 下载地址 百度网盘 提取码&#xff1a;Chen 官网 安装jdk8 双击打开下载的安装包 点击下一步 更改安装目录 点击下一步 修改Java安装目录 点击下一步 完成 配置环境变量 按住WindowsR 打开运行窗口 输入 sysdm.cpl 打开系统属性——》高级—…

华为机试题:HJ102 字符统计(python)

文章目录&#xff08;1&#xff09;题目描述&#xff08;2&#xff09;Python3实现&#xff08;3&#xff09;知识点详解1、input()&#xff1a;获取控制台&#xff08;任意形式&#xff09;的输入。输出均为字符串类型。1.1、input() 与 list(input()) 的区别、及其相互转换方…

【Redis】Redis分片集群

【Redis】Redis分片集群 文章目录【Redis】Redis分片集群1. 搭建分片集群1.1 分片集群结构1.2 搭建分片集群1.2.1 集群结构1.2.2 准备实例和配置1.2.3 启动1.2.4 创建集群1.2.5 测试2. 散列插槽2.1 总结3. 集群伸缩4. 故障转移4.1 数据迁移5. RedisTemplate访问分片集群1. 搭建…