目录
  • C++vector用法整理
    • 1.头文件
    • 2.vector初始化
    • 3.vector对象的重要操作
      • 1.赋值(assign)
      • 2.返回元素值
      • 3.清空、判断是否为空
      • 4.删除
      • 5.插入
      • 6.返回vector的现存元素个数、共可容纳个数
      • 7.调整元素个数(这个好牛)
      • 8.整体性交换
      • 9.向量的比较操作
      • 10.重要算法
    • 4.一些误区
    • 总结

      C++vector 用法整理

      1.头文件

      #include<iostream>//容器
      #include<vector> //算法
      #include<iterator>//迭代器
      

      一个代码示例

      #include<iostream>//容器
      #include<vector> //算法
      #include<iterator>//迭代器
      using namespace std;
      int main(int argc, const char* argv[])
      {
          const int SIZE = 6;
          int array[SIZE] = {1,2,3,4,5,6};
          vector<int> v(array,array+SIZE);
          cout<<"First element:"<<v.front()<<"\n Last element"<<v.back()<<endl;
         
      }
      

      2.vector初始化

      定义十个整形元素的向量(其中初值不确定)

      vector<int> a(10);
      

      每个元素初值为1;

      vector<int> a(10,1);
      

      类似于深拷贝的整体赋值方式

      vector<char> a(b);
      
      vector<char> a(b.begin(),b.begin+3);//(a的值为0~2个元素)
      

      用数组赋初值(和上面一个有点相似)

      vector<int> a(b, b+7);
      

      3.vector对象的重要操作

      1.赋值(assign)

      a.assign(b.begin(),b.begin()+3); //注意!此处,将b 0~2个元素构成的向量赋值给a!与上面不同!
      
      a.assign(4,2);//  与vector<int> a(10,1);结果相同
      

      2.返回元素值

      //返回最后一个元素
      a.back();
      //返回第一个元素
      a.front();
      //数组返回式
       a[i];
      

      3.清空、判断是否为空

      a.clear();
      
      a.empty();
      

      4.删除

      //删除最后一个元素
      a.pop_back();
      //删除一块元素
      a.erase(a.begin(),a.begin()+3);
      

      5.插入

      //在最后一个向量后插入一个元素
      a.push_back(5);
      // 插入一段元素(从第一个元素算起,插入3个数,值都为5)
      a.insert(a.begin(), 3, 5);
      //用数组插入一段元素(在a的第一个元素的位置插入b的第3个元素到第5个元素)
      a.insert(a.begin(), b+1,b+6);
      
      
      //从现有向量中选择元素向向量中添加
      int a[6] = {1, 2, 3, 4, 5, 6};
      vector<int> b;
      wector<int> c(a, a+4);
      for(vector<int>::iterator it = c.begin(); it<c.end():it++)
      {
          b.push_back(*it);
      }
      
      
      //从文件读取元素向向量中添加
      ifstream in("data.txt");
      vector<int> a;
      for(int i;in>>i)
      {
          a.push_back(i);
      }
      

      6.返回vector的现存元素个数、共可容纳个数

      a.size();
      
      a.c apacity();
      

      7.调整元素个数(这个好牛)

      //将元素个数调整至10,多删少补,补的值随机
      a.resize(10);
      //将元素个数调整至10,多删少补,补的值为2
      a.resize(10,2);
      //大容量扩充(不补充值)
      a.reserve(100);
      

      8.整体性交换

      a.swap(b);
      

      9.向量的比较操作

      a==b;
      //还有 !=  >=  <=  >  <
      

      10.重要算法

      //从小到大排列
      sort(a.begin(), a.end());
      //倒置但不排列
       reverse(a.begin(),a.end());
      //元素复制
      copy(a.begin(),a.end(),b.begin());
      //从某一区块中查找元素值,返回位置
      find(a.begin(),a.end(),10);
      

      4.一些误区

      下标只能获取已存在的元素,不能进行赋值操作

      //错误示例
      vector<int> a;
      for(int i = 0;i<10;i++)
          a[i] = i;
      

      总结

      本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注的更多内容!      

      声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。