目录 [-]
说明
构造
方法
例子
vector 类中定义了4中种构造函数

· 默认构造函数,构造一个初始长度为0的空向量,如:vector<int> v1; · 带有单个整形参数的构造函数,此参数描述了向量的初始大小。
  
说明
  vector是一种动态数组,是基本数组的类模板。其内部定义了很多基本操作。
  #include <vector> 注意:头文件没有“.h”
构造:
  这个构造函数还有一个可选的参数,这是一个类型为T的实例,描述了各个向量种各成员的初始值;
  如:vector<int> v2(init_size,0); 如果预先定义了:int init_size;他的成员值都被初始化为0;
  · 复制构造函数,构造一个新的向量,作为已存在的向量的完全复制;
  如:vector<int> v3(v2);
  · 带两个常量参数的构造函数,产生初始值为一个区间的向量。区间由一个半开区间[first,last](MS word的显示可能会有问题,first前是一个左方括号,last后面是一个右圆括号)来指定。
  如:vector<int> v4(first,last) vector<int> v1;
  vector<int> v2(init_size,0);
  vector<int> v3(v2);
方法:
  c.assign(beg,end) c.assign(n,elem) 将(beg; end)区间中的数据赋值给c。将n个elem的拷贝赋值给c。
  c. at(idx) 传回索引idx所指的数据,如果idx越界,抛出out_of_range。
  c.back() 传回最后一个数据,不检查这个数据是否存在。
  c.begin() 传回迭代器中的第一个数据地址。
  c.capacity() 返回容器中数据个数。
  c.clear() 移除容器中所有数据。
  c.empty() 判断容器是否为空。
  c.end() // 指向迭代器中末端元素的下一个,指向一个不存在元素。
  c.erase(pos) // 删除pos位置的数据,传回下一个数据的位置。
  c.erase(beg,end) 删除[beg,end)区间的数据,传回下一个数据的位置。
  c.front() 传回第一个数据。
  get_allocator 使用构造函数返回一个拷贝。
  c.insert(pos,elem) // 在pos位置插入一个elem拷贝,传回新数据位置 
  c.insert(pos,n,elem) // 在pos位置插入n个elem数据,无返回值 
  c.insert(pos,beg,end) // 在pos位置插入在[beg,end)区间的数据。无返回值 
  c.max_size() 返回容器中最大数据的数量。 
  c.pop_back() 删除最后一个数据。 
  c.push_back(elem) 在尾部加入一个数据。 
  c.rbegin() 传回一个逆向队列的第一个数据。 
  c.rend() 传回一个逆向队列的最后一个数据的下一个位置。 
  c.resize(num) 重新指定队列的长度。 
  c.reserve() 保留适当的容量。 
  c.size() 返回容器中实际数据的个数。 
  c1.swap(c2) // 将c1和c2元素互换
例子:
  为了帮助理解向量的概念,这里写了一个小例子,其中用到了vector的成员函数:begin(),end(),push_back(),assign(),front(),back(),erase(),empty(),at(),size()。
  //stl_cpp_8.cpp
  #include <iostream>
  #include <vector>
  using namespace std;
  typedef vector<int> INTVECTOR;//自定义类型INTVECTOR
  //测试vector容器的功能
  void main(void)
  {
  //vec1对象初始为空
  INTVECTOR vec1;
  //vec2对象最初有10个值为6的元素
  INTVECTOR vec2(10,6);
  //vec3对象最初有3个值为6的元素,拷贝构造
  INTVECTOR vec3(vec2.begin(),vec2.begin()+3);
  //声明一个名为i的双向迭代器
  INTVECTOR::iterator i;
  //从前向后显示vec1中的数据
  cout<<"vec1.begin()--vec1.end():"<<endl;
  for (i =vec1.begin(); i !=vec1.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //从前向后显示vec2中的数据
  cout<<"vec2.begin()--vec2.end():"<<endl;
  for (i =vec2.begin(); i !=vec2.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //从前向后显示vec3中的数据
  cout<<"vec3.begin()--vec3.end():"<<endl;
  for (i =vec3.begin(); i !=vec3.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //测试添加和插入成员函数,vector不支持从前插入
  vec1.push_back(2);//从后面添加一个成员
  vec1.push_back(4);
  vec1.insert(vec1.begin()+1,5);//在vec1第一个的位置上插入成员5
  //从vec1第一的位置开始插入vec3的所有成员
  vec1.insert(vec1.begin()+1,vec3.begin(),vec3.end());
  cout<<"after push() and insert() now the vec1 is:" <<endl;
  for (i =vec1.begin(); i !=vec1.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //测试赋值成员函数
  vec2.assign(8,1); // 重新给vec2赋值,8个成员的初始值都为1
  cout<<"vec2.assign(8,1):" <<endl;
  for (i =vec2.begin(); i !=vec2.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //测试引用类函数
  cout<<"vec1.front()="<<vec1.front()<<endl;//vec1第零个成员
  cout<<"vec1.back()="<<vec1.back()<<endl;//vec1的最后一个成员
  cout<<"vec1. at(4)="<<vec1. at(4)<<endl;//vec1的第五个成员
  cout<<"vec1[4]="<<vec1[4]<<endl;
  //测试移出和删除   // 此时 vec1为: 2 6 6 6 5 4
  vec1.pop_back();//将最后一个成员移出vec1  //此时 vec1: 2 6 6 6 5
  vec1.erase(vec1.begin()+1,vec1.end()-2);//删除成员-- //begin()+1 指的是从左到右的第一个6, end()-2指的是从右到左第1个6, erase的结果后 vec1成了 2,6,5

  cout<<"vec1.pop_back() and vec1.erase():" <<endl;
  for (i =vec1.begin(); i !=vec1.end(); ++i)
  cout << *i << " ";
  cout << endl;
  //显示序列的状态信息
  cout<<"vec1.size(): "<<vec1.size()<<endl;//打印成员个数
  cout<<"vec1.empty(): "<<vec1.empty()<<endl;//判断vec1是否为空,空则返回1,不空返回0
  }
  push_back()是将数据放入vector(向量)或deque(双端队列)的标准函数。Insert()是一个与之类似的函数,然而它在所有容器中都可以使用,但是用法更加复杂。end()实际上是取末尾加一,以便让循环正确运行--它返回的指针指向最靠近数组界限的数据。

最新文章

  1. ztree-demo 2
  2. C#中判断字符是否大写
  3. Shell脚本学习入门(一)
  4. Mysql_mysql 性能分析及explain用法
  5. matlab 相同函数名解决
  6. PostgreSql中如何kill掉正在执行的sql语句
  7. Python新手学习基础之运算符——算术运算符
  8. [原创]Web前端开发——让ie 7 8支持表单的placeholder属性
  9. Word2Vec在中文的应用
  10. 【求Java工程师/专家】大型互联网公司急招
  11. git submoudle提交
  12. python——虚拟环境之pipenv的安装及使用(windows10,64位)
  13. LuoGu P2783 有机化学之神偶尔会做作弊
  14. JBPM工作流(五)——执行流程实例
  15. MySQL客户端工具的选择
  16. Netty 高性能之道 FastThreadLocal 源码分析(快且安全)
  17. UI自动化的痛点
  18. 算法总结之 在单链表和双链表中删除倒数第k个节点
  19. atomic integer 实现
  20. InetAddress 类简介

热门文章

  1. Myeclipse发布第一个jsp页面及web project部署到tomcat上的几种方法
  2. javascript中两种基本常用排序算法分析
  3. hive中select中DISTINCT的技巧和使用
  4. linux配置tomcat已service方式启动
  5. selenium +python之Page Obiect设计模式
  6. C# 向服务器上传文件(客服端winform、服务端web)
  7. python爬虫之路——初识函数与控制语句
  8. 感觉单链表是实现BCL ICollection 的最佳方式,所有操作都能以最小的时间复杂度完成
  9. Write Once, Run Anywhere:这不是Java,这是C#
  10. centos7 python3 Saltstack配置