文章目录
STL在C++中起到非常重要的作用,最大的好处就是将常见的数据结构进行了封装,使得我们不需要从底层一步步去实现,使用起来非常方便。C++知识小屋🏠的STL系列旨在将常见STL库的常见函数进行小结,以函数+示例+结果展示的方式作为文章的整体结构。希望能够在用到这些库的时候能够快速上手,熟练地使用它们来解决一些常见的问题。
list
-
list本质上是一个双向链表,与vector类似,能够添加和删除元素。
-
对于需要频繁增加和删除操作的时候,使用list的效率比使用vector的效率要高,因为list添加和删除元素只需要改变指针指向的位置即可。而vector中添加和删除元素需要挪动该元素后面的所有元素,花费的时间较大。
-
list的缺点是不能直接用下标的形式访问,需要用迭代器的方式找到指定的元素。
-
list需要包含库:
#include <list>
-
list常见的函数如下,拿list< int > A举例子:
1.A.push_back(1) :添加元素1
2. A.pop_back() :删除A末尾的元素(最后添加的元素)
3. 用迭代器输出整个list
for(list<int>::iterator it = A.begin();it!=A.end();it++){
cout << *it << " ";
}
用list实现约瑟夫环
- 需要输入n和k,n表示一共有n个元素,k表示每个k个元素弹出
- 整体思路:通过迭代器不断在list内部遍历,当到达指定条件的时候则弹出相应的元素。且当迭代器指向list的end的时候,需要手动归位为begin,即人为构成闭环。
- 迭代器开始指向list的起点,往后遍历到第k次的时候,弹出元素,并指向下一个位置
- 下面举个例子来说明(n=6,k=2):
- 迭代器开始指向1,因为当前元素也算一次遍历,所以需要再往后遍历k-1(1)个元素到达2,此时将2弹出。(list:1 3 4 5 6)
- 接着迭代器指向3,往后遍历 k-1(1)个元素到达4,弹出4.(list:1 3 5 6)
- 接着迭代器指向5,往后遍历 k-1(1)个元素到达6,弹出6.(list:1 3 5)
- 此时迭代器自加后指向end,已经到达list的末尾,因此人为将其指向list的开端1,往后遍历 k-1(1)个元素到达3,弹出3.(list:1 5)
- 接着迭代器指向5,再往后遍历 k-1(1)个元素到达end,人为将其指向list的开端1,弹出1.(list:5)
- 接着迭代器指向5,再往后遍历 k-1(1)个元素到达end,人为将其指向list的开端5,弹出5.(list:)
#include <iostream>
#include <list>
using namespace std;
int main() {
int n,k;
cout << "请输入n和k的大小:" << endl;
cin >> n >> k;
//创建list及里面的内容
list<int> A;
for(int i=1;i<=n;i++){
A.push_back(i);
}
list<int>::iterator it = A.begin();
cout << "约瑟夫环依次弹出的元素为: " ;
while(!A.empty()){
for(int i=0;i<k-1;i++){
it++;
if(it == A.end()) //若到达list的末尾,指向开头,相当于形成环
it = A.begin();
}
cout << *it << " "; //输出当前弹出元素
A.erase(it++); //删除当前元素,并指向下一个元素
if(it == A.end()){ //若到达list的末尾,指向开头,相当于形成环
it = A.begin();
}
}
cout << endl;
return 0;
}