list的常用操作

list的介绍

list是序列容器,它允许在常数范围O(1)进行插入和删除在这段序列的任意位置,并且可以双向遍历

它是弥补vector容器的缺点,与vector有互补的韵味,

这里我们可以将其进行与vector进行对比

vector

(1)可以在序列内的任意位置随机访问,这样就很好的支持了二分查找,堆排序等

(2)头部和中间插入和删除的时候效率低,扩容的时候会多扩容空间,一定程度上浪费空间

list

(1)不支持在任意位置随机访问

(2)支持了在任意位置的插入和删除,并且是常数时间O(1)扩容是一个一个链接的不会存在多扩容空间

list的常见使用

list的操作有很多,这里我们只介绍一些比较常用的操作

(1)包头文件

要使用list向将头文件包上

cpp 复制代码
#include<iostream>
#include<list>

using namespace std;

(2)头插头删尾插尾删

list的底层是双向链表自然也就支持头插头删尾插尾删

建立list对象l后,我们就可以进行使用了

cpp 复制代码
list <int> l;

l.push_back(1);
l.push_back(2);
l.push_back(3);
l.push_back(4);

l.push_front(0);

l.pop_back();
l.pop_front();

(3)list的打印

list的遍历不能使用operator[]+下标进行遍历,其根本的物理结构不相同

list的遍历使用迭代器或则范围for进行遍历,其中范围for是编译器自动替换为迭代器iterator进行打印

cpp 复制代码
    list<int>::iterator it = l.begin();
	while (it != l.end())
	{
		cout << *it << " ";
		++it;
	}
	cout << endl;

	for (auto e : l)
	{
		cout << e << " ";
	}
	cout << endl;

打印(2)中的结果如下

(4)反向打印迭代器

list的底层是双向循环列表,支持反向遍历打印

cpp 复制代码
	list<int>::reverse_iterator rit = l.rbegin();
	while (rit != l.rend())
	{
		cout << *rit << " ";
		++rit;
	}
	cout << endl;

运行结果如下

(5)修改

在迭代器以及范围for中我们可以修改list中的值,如下

cpp 复制代码
	list<int>::iterator it = l.begin();
	while (it != l.end())
	{
		*it += 1;
		cout << *it << " ";
		++it;
	}
	cout << endl;

结果如下

(6)仅打印print_list

cpp 复制代码
void print_list(const list<int>& l)
{
	list<int>::const_iterator it = l.begin();
	while (it != l.end())
	{
		//*it += 1;不能更改
		cout << *it << " ";
		++it;
	}
	cout << endl;
}

这里更改的话,编译器会提示错误,原因是const类型的迭代器仅能读,不能写

结果如下

(7)赋值运算符=

cpp 复制代码
	list<int> lt1;
	lt1.push_back(10);
	lt1.push_back(20);
	lt1.push_back(30);
	lt1.push_back(40);

	l = lt1;
	print_list(l);

打印结果为,可知l中的原值1,2,3被赋值为10,20,30,40

(8)查找,插入,删除

cpp 复制代码
list<int> lt1;
lt1.push_back(1);
lt1.push_back(2);
lt1.push_back(3);
lt1.push_back(4);
cpp 复制代码
list<int>::iterator it = find(lt1.begin(),lt1.end(),3);
if (it != lt1.end())
{
	lt1.insert(it, 30);
	lt1.erase(it);
}

结果为,这里有的时候会涉及迭代器的失效,请期待下节

(9)排序

cpp 复制代码
list<int> lt1;
lt1.push_back(3);
lt1.push_back(5);
lt1.push_back(1);
lt1.push_back(6);
lt1.push_back(2);
lt1.push_back(4);

print_list(lt1);

lt1.sort();

结果如下

到这里我们讲解完毕

如果对您有帮助的话点一个免费的赞和收藏叭!

由于作者水平不足,如有任何错误,请读者在评论区交流!

相关推荐
UP_Continue1 小时前
排序--计数排序
数据结构·算法
嵌入式@秋刀鱼7 小时前
《第四章-筋骨淬炼》 C++修炼生涯笔记(基础篇)数组与函数
开发语言·数据结构·c++·笔记·算法·链表·visual studio code
嵌入式@秋刀鱼7 小时前
《第五章-心法进阶》 C++修炼生涯笔记(基础篇)指针与结构体⭐⭐⭐⭐⭐
c语言·开发语言·数据结构·c++·笔记·算法·visual studio code
泽02027 小时前
C++之list的自我实现
开发语言·数据结构·c++·算法·list
物联网嵌入式小冉学长10 小时前
2.线性表的链式存储-链表
数据结构·链表
顾小玙10 小时前
前缀和:leetcode974--和可被K整除的子数组
数据结构·算法
W说编程11 小时前
算法导论第三章:数据结构艺术与高效实现
c语言·数据结构·算法
hn小菜鸡12 小时前
LeetCode 2917.找出数组中的K-or值
数据结构·算法·leetcode
yield-bytes13 小时前
Java并发进阶系列:深度讨论高并发跳表数据结构ConcurrentSkipListMap的源代码实现(上)
数据结构
好易学·数据结构13 小时前
可视化图解算法51:寻找第K大(数组中的第K个最大的元素)
数据结构·python·算法·leetcode·力扣·牛客网·堆栈