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

简介: C++|STL-list运用(1)

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初始化mylist1
 
list<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,第二个2
  list<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,第二个2
  cout << "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,第二个2
  cout << "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,第二个2
  cout << "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,第二个2
  cout << "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,第二个2
  cout << "clear()前——检测链表是否为空mylist——" << mylist.empty() << endl;
  mylist.clear();
  cout << "clear()后——检测链表是否为空mylist——" << mylist.empty() << endl;
 
 
  return 0;
}



 


相关文章
|
4天前
|
编译器 C语言 C++
【c++丨STL】list模拟实现(附源码)
本文介绍了如何模拟实现C++中的`list`容器。`list`底层采用双向带头循环链表结构,相较于`vector`和`string`更为复杂。文章首先回顾了`list`的基本结构和常用接口,然后详细讲解了节点、迭代器及容器的实现过程。 最终,通过这些步骤,我们成功模拟实现了`list`容器的功能。文章最后提供了完整的代码实现,并简要总结了实现过程中的关键点。 如果你对双向链表或`list`的底层实现感兴趣,建议先掌握相关基础知识后再阅读本文,以便更好地理解内容。
14 1
|
17天前
|
算法 C语言 C++
【c++丨STL】list的使用
本文介绍了STL容器`list`的使用方法及其主要功能。`list`是一种双向链表结构,适用于频繁的插入和删除操作。文章详细讲解了`list`的构造函数、析构函数、赋值重载、迭代器、容量接口、元素访问接口、增删查改操作以及一些特有的操作接口如`splice`、`remove_if`、`unique`、`merge`、`sort`和`reverse`。通过示例代码,读者可以更好地理解如何使用这些接口。最后,作者总结了`list`的特点和适用场景,并预告了后续关于`list`模拟实现的文章。
33 7
|
25天前
|
存储 编译器 C++
C++ initializer_list&&类型推导
在 C++ 中,`initializer_list` 提供了一种方便的方式来初始化容器和传递参数,而右值引用则是实现高效资源管理和移动语义的关键特性。尽管在实际应用中 `initializer_list&&` 并不常见,但理解其类型推导和使用方式有助于深入掌握现代 C++ 的高级特性。
16 4
|
3月前
|
存储 搜索推荐 C++
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器2
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
67 2
|
3月前
|
存储 算法 C++
【C++打怪之路Lv10】-- list
【C++打怪之路Lv10】-- list
24 1
|
3月前
|
存储 C++ 容器
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器1
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
74 5
|
3月前
|
存储 编译器 C++
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
【C++篇】揭开 C++ STL list 容器的神秘面纱:从底层设计到高效应用的全景解析(附源码)
85 2
|
3月前
|
C++
【C++】C++ STL 探索:List使用与背后底层逻辑(三)
【C++】C++ STL 探索:List使用与背后底层逻辑
|
3月前
|
C++
【C++】C++ STL 探索:List使用与背后底层逻辑(二)
【C++】C++ STL 探索:List使用与背后底层逻辑
|
3月前
|
存储 编译器 C++
【C++】C++ STL 探索:List使用与背后底层逻辑(一)
【C++】C++ STL 探索:List使用与背后底层逻辑