C++知识小屋(8):STL——list常见函数小结

文章目录

  • list
  • 用list实现约瑟夫环

       STL在C++中起到非常重要的作用,最大的好处就是将常见的数据结构进行了封装,使得我们不需要从底层一步步去实现,使用起来非常方便。C++知识小屋的STL系列旨在将常见STL库的常见函数进行小结,以函数+示例+结果展示的方式作为文章的整体结构。希望能够在用到这些库的时候能够快速上手,熟练地使用它们来解决一些常见的问题。

list

  • list本质上是一个双向链表,与vector类似,能够添加和删除元素。

  • 对于需要频繁增加和删除操作的时候,使用list的效率比使用vector的效率要高,因为list添加和删除元素只需要改变指针指向的位置即可。而vector中添加和删除元素需要挪动该元素后面的所有元素,花费的时间较大。

  • list的缺点是不能直接用下标的形式访问,需要用迭代器的方式找到指定的元素。

  • list需要包含库:#include

  • 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:)
      C++知识小屋(8):STL——list常见函数小结_第1张图片
#include 
#include 
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;
}

C++知识小屋(8):STL——list常见函数小结_第2张图片

你可能感兴趣的:(C++)