容器类型小记

来源:互联网 发布:javascript 第7版 pdf 编辑:程序博客网 时间:2024/06/07 02:42

顺序容器类型:

                        顺序容器   

                                        vector:支持快速随机访问

                                        list:支持快速插入/删除

                                        deque:双端队列

                        顺序容器适配器:

                                        stack:后进先出

                                        queue:先进先出

                                         priority_queue:有优先级管理的队列

1.基本操作

   vector      

(1)头文件#include<vector>.

(2)创建vector对象,vector<int> vec;

(3)尾部插入数字:vec.push_back(a);

(4)使用下标访问元素,cout<<vec[0]<<endl;记住下标是从0开始的。

(5)使用迭代器访问元素.

(6)插入元素:    vec.insert(vec.begin()+i,a);在第i+1个元素前面插入a;

(7)删除元素:    vec.erase(vec.begin()+2);删除第3个元素

vec.erase(vec.begin()+i,vec.end()+j);删除区间[i,j-1];区间从0开始

(8)向量大小:vec.size();

(9)清空:vec.clear();

(10)使用reverse将元素翻转:需要头文件#include<algorithm>,reverse(vec.begin(),vec.end())

(11)使用sort排序:需要头文件#include<algorithm>,sort(vec.begin(),vec.end());(默认是按升序排列,即从小到大)

(12)使用unique去重 unique(vec.begin(),vec.end())

list  与 向量(vector)相比, 它允许快速的插入和删除,但是随机访问却比较慢。

从前插入元素  list<int> ilist ;  ilist.push_front(2);

从后插入元素 ilist.push_back(2);

accumulate 累加算法 int result=accumulate(ilist.begin(),ilist.end(),0);

在序列中间插入元素 ilist.insert(++ilist.begin(),3,9)  在第一个元素后插入3个9

前后各移除一个元素  ilist.pop_front()  ilist.pop_back()

赋值 ilist.assign(8,1)

排序 sort 

deque

    (1) 随机访问方便,即支持[ ] 操作符和vector.at() ,但性能没有vector 好;

    (2) 可以在内部进行插入和删除操作,但性能不及list 

    (3) 可以在两端进行push pop 

    (4) 相对于verctor 占用更多的内存。

双向队列和向量很相似,但是它允许在容器头部快速插入和删除(就像在尾部一样)。

 

1.Constructors 创建一个新双向队列

   语法:

      deque();//创建一个空双向队列

      deque( size_type size );// 创建一个大小为size的双向队列

      deque( size_type num, const TYPE &val ); //放置numval的拷贝到队列中

      deque( const deque &from );// from创建一个内容一样的双向队列

      deque( input_iterator start, input_iterator end );

      // start 和 end - 创建一个队列,保存从startend的元素。

2.Operators 比较和赋值双向队列

      //可以使用[]操作符访问双向队列中单个的元素

3.assign() 设置双向队列的值

   语法:

      void assign( input_iterator start, input_iterator end);

      //startend指示的范围为双向队列赋值

      void assign( Size num, const TYPE &val );//设置成numval

4.at() 返回指定的元素 

5.back() 返回最后一个元素

6.begin() 返回指向第一个元素的迭代器

7.clear() 删除所有元素

8.empty() 返回真如果双向队列为空

9.end() 返回指向尾部的迭代器

10.erase() 删除一个元素

      iterator erase( iterator pos ); //删除pos位置上的元素

      iterator erase( iterator start, iterator end ); //删除startend之间的所有元素

      //返回指向被删除元素的后一个元素

11.front() 返回第一个元素的引用

12.get_allocator() 返回双向队列的配置器

13.insert() 插入一个元素到双向队列中

      iterator insert( iterator pos,  num, val ); //pos前插入numval

      void insert( iterator pos, input_iterator start, input_iterator end );

      //插入从startend范围内的元素到pos前面

14.max_size() 返回双向队列能容纳的最大元素个数

15.pop_back() 删除尾部的元素

16.pop_front() 删除头部的元素

17.push_back() 在尾部加入一个元素

18.push_front() 在头部加入一个元素

19.rbegin() 返回指向尾部的逆向迭代器

20.rend() 返回指向头部的逆向迭代器

21.resize() 改变双向队列的大小

22.size() 返回双向队列中元素的个数

23.swap() 和另一个双向队列交换元素

stack
stack 模板类的定义在<stack>头文件中。
stack 模板类需要两个模板参数,一个是元素类型,一个容器类型,但只有元素类型是必要
的,在不指定容器类型时,默认的容器类型为deque。
定义stack 对象的示例代码如下:
stack<int> s1;
stack<string> s2;
stack 的基本操作有:
入栈,如例:s.push(x);
出栈,如例:s.pop();注意,出栈操作只是删除栈顶元素,并不返回该元素。
访问栈顶,如例:s.top()
判断栈空,如例:s.empty(),当栈空时,返回true。
访问栈中的元素个数,如例:s.size()。

queue
queue 模板类的定义在<queue>头文件中。
与stack 模板类很相似,queue 模板类也需要两个模板参数,一个是元素类型,一个容器类
型,元素类型是必要的,容器类型是可选的,默认为deque 类型。
定义queue 对象的示例代码如下:
queue<int> q1;
queue<double> q2;

queue 的基本操作有:
入队,如例:q.push(x); 将x 接到队列的末端。
出队,如例:q.pop(); 弹出队列的第一个元素,注意,并不会返回被弹出元素的值。
访问队首元素,如例:q.front(),即最早被压入队列的元素。
访问队尾元素,如例:q.back(),即最后被压入队列的元素。
判断队列空,如例:q.empty(),当队列空时,返回true。
访问队列中的元素个数,如例:q.size()




0 0
原创粉丝点击