【C++ 与 STL】动态数组:vector

摘自:博主柳婼

vector是一个模板类 所以使用时要用vector<int> a 或者 vector<double> b这样的方式来声明一个vector

vector<int> 是一个类似于 int a[] 的整数数组,而 vector<string> 是一个类似于 string a[] 的字符串数组
clear() 清空
resize() 改变大小
push_back() 在尾部添加元素
pop_back() 在尾部删除元素
empty() 测试是否为空
vector 之间可以直接赋值或者作为函数的返回值
push_back() pop_back() 无需改变数组长度,自动会增加和减小数组长度
增加长度后增加的元素值为 0

测试代码:

  1. #include <iostream>  
  2. #include <vector>  
  3. using namespace std;  
  4.   
  5. int main() {  
  6.     vector<int> a;  
  7.     int t;  
  8.     for (int i = 0; i < 10; i++) { cin >> t;  
  9.         a.push_back(t);  
  10.     }  
  11.     vector<int> b;  
  12.     b = a;  
  13.     cout << "print b: 直接赋值" << endl;  
  14.     for (int i = 0; i < b.size(); i++) {  
  15.         cout << b[i] << " ";  
  16.     }  
  17.     cout << endl;  
  18.     cout << "a.size() = " << a.size() << endl;  
  19.       
  20.     cout << "print1:" << endl;  
  21.     for (int i = 0; i < a.size(); i++) {  
  22.         cout << a[i] << " ";  
  23.     }  
  24.     cout << endl;  
  25.       
  26.     a.resize(11);  
  27.     cout << "a.size() = after resize(11) :" << a.size() << endl;  
  28.     cout << "print2 after resize(11):" << endl;  
  29.     for (int i = 0; i < a.size(); i++) {  
  30.         cout << a[i] << " ";  
  31.     }  
  32.     cout << endl;  
  33.       
  34.     a.push_back(22);  
  35.     cout << "print3 after push_back(22):" << endl;  
  36.     for (int i = 0; i < a.size(); i++) {  
  37.         cout << a[i] << " ";  
  38.     }  
  39.     cout << endl;  
  40.       
  41.     a.pop_back();  
  42.     cout << "a.size() = after pop_back() :" << a.size() << endl;  
  43.     cout << "print4 after pop_back():" << endl;  
  44.     for (int i = 0; i < a.size(); i++) {  
  45.         cout << a[i] << " ";  
  46.     }  
  47.     cout << endl;  
  48.     cout << "a.empty()?:" << a.empty() << endl;  
  49.     a.clear();  
  50.     cout << "a.size() = after a.clear() :" << a.size() << endl;  
  51.     cout << "print5 after a.clear():" << endl;  
  52.     for (int i = 0; i < a.size(); i++) {  
  53.         cout << a[i] << " ";  
  54.     }  
  55.     cout << endl;  
  56.     return 0;  
  57. }  

c.assign(beg,end)  (beg; end)区间中的数据赋值给c
c.assign(n,elem) nelem的拷贝赋值给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位置插入nelem数据,返回值
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) // c1c2元素互换

猜你喜欢

转载自blog.csdn.net/el_apocalipsis/article/details/79445598