动态数组,使用方法与python数组类似
 
1.定义和初始化
 
| vector<type> name | 创建一个名为nama的type类型vector | 
| vector<type> name={val1,val2,val3} | 创建数组并初始化为[val1,val2,val3] | 
| vector<type> name2(name1) | 使用name1的元素初始化name2(深拷贝,name1和name2的操作互不影响) | 
| vector<type> name(n,val) | 创建一个名为name的数据类型为type的vector,并且初始化为包含了n个val | 
| vector<type> name(n) | name包含n个默认值初始化 | 
| vector<vector<type>> matrix(M,vector<type>(N)) | 二维数组初始化,创建M*N的二维矩阵 | 
 
 
vector<int> v;//创建一个名为v的int类型数组
vector<int> v={1,2,3};//创建一个名为v的int类型数组,并初始化为[1,2,3]
vector<char> v2(v1);//使用char类型数组v1初始化v2
vector<int> v(10,1);//创建一个int类型数组v,包含10个元素都为1
vector<char> v(5);//创建一个char类型数组,包含5个元素
vector<vector<int>> matrix(10,vector<int> (5));//创建一个尺寸为10*5的二维int类型矩阵,初始化默认为0
 
2.常用api
 
| api | 作用 | 说明 | 
| push_back(val) | 增 | 末尾添加元素val,深拷贝 | 
| pop_back | 删 | 删除末尾元素 | 
| v[index]=val | 改 | 修改下标为index的值为val | 
| v.size() | 返回v中元素个数 |  | 
| v.clear() | 清空数组 | 等效于v={} | 
 
int main() {vector<int> v = { 1,2,3 };//创建vector,并初始化为[1,2,3]//1.增加元素v.push_back(4);//[1,2,3,4]//2.删除元素v.pop_back();//[1,2,3]//3.修改v[0] = 0;//[0,2,3]//4.查看数组大小cout << v.size() << endl;//输出3//5.清空数组v.clear();cout << v.size();
}
 
 
3.遍历元素
 
int main() {vector<int> v = { 1,2,3 };//创建数组//auto表示自动分配数据类型,&表示创建temp应用,可以通过修改temp修改数组的值for (auto& temp : v){temp = temp + 1;//遍历数组所有元素并+1}for (auto& temp : v){cout << temp << endl;//循环三次,依次输出2,3,4}
}
 
4.其他常用操作
 
| v1==v2 | 判断两vector相等,长度与内容都相等时才为true | 
| v2=v1 | 用v1的元素替换v2的元素(深拷贝,互不影响) | 
| sort | 排序,直接修改原数组内容,无返回值。配合begin、end,rbegin、rend实现正反排序 | 
 
int main() {vector<int> v = { 4,1,2,3 };//创建数组sort(v.begin(), v.end());//由小到大排序[1,2,3,4]for (int temp : v)//打印输出{cout << temp << endl;}sort(v.rbegin(), v.rend());//由大到小排序[4,3,2,1]for (int temp : v)//打印输出{cout << temp << endl;}
}