vector动态数组
时间: 2023-10-23 16:10:31 浏览: 52
vector是C++ STL库中提供的一种动态数组容器,可以方便地管理一组元素。它能够自动调整大小,并且支持添加、删除和访问元素的操作。在使用vector之前,我们需要包含< vector> 头文件。
vector提供了多个构造函数,可以根据需求选择适合的构造函数来创建vector对象。其中包括:
- vector():创建一个空的vector。
- vector(int nSize):创建一个包含nSize个元素的vector。
- vector(int nSize, const t& t):创建一个包含nSize个元素且值均为t的vector。
- vector(const vector& ):复制构造函数,创建一个与已有vector相同的vector对象。
- vector(begin, end):创建一个包含[begin, end)区间内另一个数组的元素的vector。
vector还提供了多个遍历函数,可以用于遍历vector中的元素。例如,可以使用reverse_iterator来逆序遍历vector。
相关问题
c++ vector 动态数组
C中的vector是一种动态数组数据结构。相对于静态数组,vector的大小是动态变化的,可以根据需要自动调整大小。
vector的底层实现是一个连续的存储空间,可以通过指针进行访问。当vector的大小超过了其内部数组的容量时,会重新分配更大的存储空间,并将原有数据拷贝到新的存储空间中。
使用vector需要引入头文件< vector.h >。通过声明vector变量并指定其存储的数据类型,可以创建一个空的vector对象。可以使用push_back()函数向vector末尾添加元素,使用pop_back()函数删除vector末尾的元素。可以使用[]运算符或at()函数来访问vector中的元素。
vector提供了一些其他有用的成员函数,如size()可以获取vector的当前大小,capacity()可以获取vector的当前容量,empty()可以判断vector是否为空,clear()可以清空vector中的所有元素等。
使用vector时需要注意的是,当插入或删除元素时,会引起内部数组的重新分配,可能会造成性能上的开销。因此,如果事先知道vector的大小,可以使用reserve()函数来预分配足够的存储空间,以避免频繁的重新分配。
总之,vector是C中常用的一种动态数组数据结构,它提供了方便的操作函数,使得动态数组的使用更加灵活和方便。
vector动态数组输入输出
vector动态数组的输入输出可以使用for循环遍历数组中的元素,然后使用cout输出每个元素。也可以使用迭代器iterator来遍历数组中的元素,使用*iterator输出每个元素。输入时可以使用push_back()函数向数组末尾添加元素,也可以使用insert()函数在指定位置插入元素。另外,可以使用resize()函数改变数组的大小。下面是一个简单的示例代码:
代码示例:
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> myVector;
int num;
// 输入
cout << "请输入一些整数,以-1结束:" << endl;
cin >> num;
while (num != -1) {
myVector.push_back(num);
cin >> num;
}
// 输出
cout << "数组中的元素为:" << endl;
for (int i = 0; i < myVector.size(); i++) {
cout << myVector[i] << " ";
}
cout << endl;
return 0;
}
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)