C++|STL-list运用(1)

server/2024/9/24 11:20:28/

cplusplus.com/reference/list/list/?kw=list

list介绍

list是一个双向循环链表,双向循环链表它的每个节点都有两个链接,一个指向前一个节点,另一个指向下一个节点,且最后一个结点指向头节点。

结点组成

1.数据域

2.指针域 :有两个指针域,一个指向前一个结点,一个指向后一个结点

优点

1.相比于单向链表,双向链表在插入和删除操作时更加灵活,因为它们可以从两个方向进行操作;

2.相比于序列式容器相比(array,vector,deque),list通常在任意位置进行插入、移除元素的执行效率更好。

缺点

1.最大的缺陷是不支持任意位置的随机访问,必须从已知的位置(比如头部或者尾部)迭代到该位置;

2.需要额外的指针来维护前一个和下一个节点的链接。

list使用

list的初始化

与vector相同,使用时要包含list头文件;声明是容器类型 <数据类型>name;

vector <int>arr;//定义了一个空的数组list <int>mylist;//定义一个空的双向循环链表

其他初始化方式还有

list<int>mylist(2,3);//定义一个里面有两个三的双向循环链表list<int>mylist1(mylist)//用mylist初始化mylist1list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2

其他函数

empty()——判空

检测list是否为空,是返回true,否则返回false

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>list1;list<int>mylist(2, 3);list<int>mylist1(mylist);cout << "检测链表是否为空list1——" << list1.empty() << endl;cout << "检测链表是否为空mylist——" << mylist.empty() << endl;return 0;
}

 

size()——数据个数

返回list中有效节点的个数

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>list1;list<int>mylist(2, 3);list<int>mylist1(mylist);cout << "list1数据个数——" << list1.size() << endl;cout << "mylist数据个数——" << mylist.size() << endl;return 0;
}

 

front()——第一个数据

返回list的第一个节点中值的引用

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>list1;list<int>mylist(2, 3);list<int>mylist1(4, 7);cout << "mylist第一个数据——" << mylist.front() << endl;cout << "mylist1第一个数据——" << mylist1.front() << endl;return 0;
}

 

back()—— 最后一个数据

返回list的最后一个节点中值的引用

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>list1;list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2list<int>mylist1 = { 3, 4 };//同上cout << "mylist最后一个数据——" << mylist.back() << endl;cout << "mylist1最后一个数据——" << mylist1.back() << endl;return 0;
}

push_front(int val)——前插

在list首元素前插入值为val的元素

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2cout << "push_front()前mylist第一个数据——" << mylist.front() << endl;mylist.push_front(1);cout << "push_front()后mylist第一个数据——" << mylist.front() << endl;return 0;
}

pop_front()——前删

删除list中第一个元素

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2cout << "pop_front()前mylist第一个数据——" << mylist.front() << endl;mylist.pop_front();cout << "pop_front()后mylist第一个数据——" << mylist.front() << endl;return 0;
}

push_back(int  val)——尾插

在list尾部插入值为val的元素

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2cout << "push_back()前mylist最后一个数据——" << mylist.back() << endl;mylist.push_back(1);cout << "push_back()后mylist最后一个数据——" << mylist.back() << endl;return 0;
}

pop_back()——尾删

删除list中最后一个元素

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2cout << "pop_back()前mylist最后一个数据——" << mylist.back() << endl;mylist.pop_back();cout << "pop_back()后mylist最后一个数据——" << mylist.back() << endl;return 0;
}

clear()——清空

清空list中的有效元素

#include<iostream>
#include<list>
using namespace std;
int main()
{list<int>mylist = { 3, 2 };//代表列表里面有两个数第一个3,第二个2cout << "clear()前——检测链表是否为空mylist——" << mylist.empty() << endl;mylist.clear();cout << "clear()后——检测链表是否为空mylist——" << mylist.empty() << endl;return 0;
}




 


http://www.ppmy.cn/server/31528.html

相关文章

深度学习之基于Matlab神经网络的活体人脸和视频人脸识别系统

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 人脸识别技术作为生物识别技术的一种&#xff0c;近年来得到了广泛的关注和应用。与传统的身份认证方…

Linux的有关权限的学习

1.认识权限在Linux中的表示 在Linux中&#xff0c;一切皆文件&#xff0c;而每个文件都会有其相对应的操作权限。那么&#xff0c;我们该怎么来认识他们呢&#xff1f; 首先我们可以看到&#xff0c;在每个test文件的前面都会有一个-rw-r--r--这个字符&#xff0c;而这个字符&…

FreeBSD下安装Linux兼容系统Ubuntu

FreeBSD有个很神奇的功能&#xff0c;就是跟Linux二进制兼容&#xff0c;也就是可以直接运行linux的bin文件。还有个更神奇的功能&#xff0c;就是能运行出一套Linux系统&#xff0c;完全是linux的用户&#xff0c;linux的目录系统&#xff0c;而且还可以选是Centos系统还是Ubu…

OpenHarmony实战开发-动画概述

UI&#xff08;用户界面&#xff09;中包含开发者与设备进行交互时所看到的各种组件&#xff08;如时间、壁纸等&#xff09;。属性作为接口&#xff0c;用于控制组件的行为。例如&#xff0c;开发者可通过位置属性调整组件在屏幕上的位置。 属性值的变化&#xff0c;通常会引…

深入浅出学习Pytorch—Pytorch简介与2024年最新安装(GPU)

深入浅出学习Pytorch—Pytorch简介 学习原因&#xff1a;Pytorch日益增长的发展速度与深度学习时代的迫切需要 Pytorch模型训练 pytorch实现模型训练包括以下的几个方面&#xff08;学习路线&#xff09; 数据&#xff1a;数据预处理与数据增强模型&#xff1a;如何构建模型模…

MATLAB中自定义栅格数据地理坐标R,利用geotifwrite写入tif

场景描述&#xff1a; 有时候将nc格式的数据转成tiff&#xff0c;或者是将一个矩阵输出成带有地理坐标信息tiff数据时&#xff0c;常常涉及到空间参考的定义和geotiffwrite()函数。 问题描述&#xff1a; 以全球数据为例&#xff0c;今天发现在matlab中对矩阵进行显示后&…

ArmSoM-Sige5 RK3576开发板 正式发布!

简介​ ArmSoM-Sige5 采用Rockchip RK3576第二代8nm高性能AIOT平台&#xff0c;6 TOPS算力NPU&#xff0c;最大可配16GB大内存。支持8K视频编解码&#xff0c;拥有丰富的接口&#xff0c;支持双千兆网口&#xff0c;WiFi6 & BT5和多种视频输出。支持多种操作系统&#xff…

嵌入式硬件中优化设计PCB提高焊接质量方法

随着电子技术的飞速发展,电子元器件的小型化、微型化、间距为0.3mm~0.5mm高密度的芯片越来越普遍,对电子焊接技术的要求也就越来越高。虽然现在有了更精密的贴片机可以代替人工焊接,但影响焊接质量的因素太多。本文将从贴片焊接的角度,介绍了几点PCB设计时需要注意的要点,…