相对于vector容器的连续线性空间,list是一个双向链表。
它有一个重要性质:插入操作和删除操作都不会造成原有的list迭代器失效,每次插入或删除一个元素就配置或释放一个元素空间。也就是说,对于任何位置的元素插入或删除,list永远是常数时间。
常用函数
list
list
list
list
list
Int size() const:返回容器元素个数
bool empty() const:判断容器是否为空,若为空则返回true
void push_back(const T& x):list元素尾部增加一个元素x
void push_front(const T& x):list元素首元素钱添加一个元素X
void pop_back():删除容器尾元素,当且仅当容器不为空
void pop_front():删除容器首元素,当且仅当容器不为空
void remove(const T& x):删除容器中所有元素值等于x的元素
void clear():删除容器中的所有元素
iterator insert(iterator it, const T& x ):在迭代器指针it前插入元素x,返回x迭代器指针
void insert(iterator it,size_type n,const T& x):迭代器指针it前插入n个相同元素x
void insert(iterator it,const_iterator first,const_iteratorlast):把[first,last)间的元素插入迭代器指针it前
iterator erase(iterator it):删除迭代器指针it对应的元素
iterator erase(iterator first,iterator last):删除迭代器指针[first,last)间的元素
iterator begin():返回首元素的迭代器指针
iterator end():返回尾元素之后位置的迭代器指针
reverse_iterator rbegin():返回尾元素的逆向迭代器指针,用于逆向遍历容器
reverse_iterator rend():返回首元素前一个位置的迭代器指针
reference front():返回首元素的引用
reference back():返回尾元素的引用
void sort():容器内所有元素排序,默认是升序
template
void swap(list& str):两list容器交换功能
void unique():容器内相邻元素若有重复的,则仅保留一个
void splice(iterator it,list& li):队列合并函数,队列li所有函数插入迭代指针it前,x变成空队列
void splice(iterator it,list& li,iterator first):队列li中移走[first,end)间元素插入迭代指针it前
void splice(iterator it,list& li,iterator first,iterator last):x中移走[first,last)间元素插入迭代器指针it前
void reverse():反转容器中元素顺序
01.#include "stdafx.h"
02.#include
03.#include
04.#include
05.using namespace std;
06.typedef list LISTINT;
07.
08.int _tmain(int argc, _TCHAR* argv[])
09.{
10. LISTINT test;
11. for(int i=0;i<5;i++)
12. {
13. test.push_back(i+1);
14. }
15.
16. LISTINT::iterator it = test.begin();
17. for(;it!=test.end();it++)
18. {
19. cout<<*it<<"\t";
20. }
21. cout<
程序运行结果如下:
01.#include "stdafx.h"
02.#include
03.#include
04.#include
05.using namespace std;
06.typedef list LISTINT;
07.
08.int _tmain(int argc, _TCHAR* argv[])
09.{
10. LISTINT test;
11. test.push_back(1);
12. test.push_back(5);
13. test.push_back(3);
14. test.push_back(10);
15.
16. LISTINT test2;
17. test2.push_back(2);
18. test2.push_back(8);
19. test2.push_back(6);
20. test2.push_back(9);
21.
22. test.sort();
23. test2.sort();
24.
25. test.merge(test2);
26.
27. for(LISTINT::iterator it = test.begin();it!=test.end();it++)
28. {
29. cout<<*it<<"\t";
30. }
31. cout<