蓝桥杯省赛无忧 STL 课件14 list

本文详细介绍了C++中的list容器,包括其定义、常用函数如push_back和push_front,以及其在插入、删除和遍历方面的特点。特别强调了list作为双向链表的特性对性能的影响,与vector和deque等其他容器的比较。
摘要由CSDN通过智能技术生成

在这里插入图片描述

01 list的定义和结构

在这里插入图片描述
在这里插入图片描述
以下是一个示例,展示如何使用listt容器:

#include<bits/stdc++.h>
using namespace std;
int main(){
	list<int> mylist;
	//在链表尾部插入元素
	mylist.push_back(1);
	mylist.push_back(2);
	mylist.push_back(3);
	//在链表头部插入元素 
	mylist.push_front(0);
	//遍历链表并输出元素
	for(int num:mylist){
		cout<<num<<" ";
	}
	cout<<endl;
	return 0;
}

在这里插入图片描述
在上述示例中,我们首先创建了一个list容器myList,然
后使用push_back()和push_front()函数分别在链表尾部和头
部插入元素。最后,使用范围基于范围的for循环遍历链
表并输出元素。
需要注意的是,由于list是双向链表,因此插入和删除操
作的时间复杂度是常量时间O(1),但访问和查找操作的
时间复杂度是线性时间O(n),其中n是链表的大小。因
此,如果需要频繁进行随机访问操作,可能更适合使用
支持随机访问的容器,如vector或deque。

02 list的常用函数

在这里插入图片描述

03 代码示例

#include<bits/stdc++.h>
using namespace std;
int main(){
	//创建一个llist<int>对象mylist
	list<int> mylist;
	//向mylist尾部添加元素
	for(int i=1;i<=5;i++){
		mylist.push_back(i);
	} 
	//从头到尾输出mylist中的元素 
	for(const auto&i : mylist)cout<<i<<' ';
	//将mylist中的元素反转
	reverse(mylist.begin(),mylist.end());
	for(const auto &i :mylist)cout<<i<<' ';
	cout<<'\n';
	//将第一个元素的后一个位置加上元素0
	mylist.insert(++mylist.begin(),0);
	for(const auto &i:mylist)cout<<i<<' ';
	cout<<'\n';
	mylist.erase(++ ++ mylist.begin(), -- mylist.end());
	//输出mylist的大小
	cout<<"链表大小为:"<<mylist.size()<<'\n';
	//从头到尾输出mylist中的元素
	for(const auto&i : mylist)cout<<i<<' ';
	cout<<'\n'; 
	return 0;
}

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值