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

01 list的定义和结构


以下是一个示例,展示如何使用listt容器:

csharp 复制代码
#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 代码示例

csharp 复制代码
#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;
}
相关推荐
七颗糖很甜20 分钟前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法
科研前沿27 分钟前
镜像视界浙江科技有限公司的关键技术突破有哪些?
大数据·人工智能·科技·算法·音视频·空间计算
嫩萝卜头儿36 分钟前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
星马梦缘1 小时前
算法设计与分析 作业二 答案与解析
算法·图论·dfs·bfs·floyd-warshall·bellman_ford·多源最短路
玛丽莲茼蒿1 小时前
Leetcode hot100 每日温度【中等】
算法·leetcode·职场和发展
cjp5601 小时前
009.UG二次开发,任务环境草图优化3(高级功能生成直线)
算法
样例过了就是过了1 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
逻辑驱动的ken1 小时前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
木木_王1 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
麦兜和小可的舅舅2 小时前
ClickHouse 列管理机制解析:从 COW、IColumn 到 CRTP
c++·clickhouse