vector
时间: 2025-06-09 08:26:30 浏览: 17
### C++中 `vector` 数据结构的使用方法
`vector` 是 C++ 标准模板库(STL)中的一个动态数组容器,提供了类似数组的操作,同时具有动态扩展和收缩的能力。以下是关于 `vector` 的构造、常用操作及函数的详细介绍[^1]。
#### 1. 构造函数
`vector` 提供了多种构造方式:
- 默认构造:`vector<int> v;` 创建一个空的 `vector`。
- 区间构造:`vector(v.begin(), v.end());` 将另一个 `vector` 的部分或全部元素拷贝到新容器中[^1]。
- 指定大小和初始值:`vector<int> v(n, elem);` 创建包含 `n` 个值为 `elem` 的元素的 `vector`。
- 拷贝构造:`vector(const vector &vec);` 创建一个与现有 `vector` 完全相同的副本[^1]。
#### 2. 常用成员函数
以下是一些常用的 `vector` 成员函数:
- **访问元素**:
- `at(index)`:通过索引访问元素,超出范围会抛出异常[^2]。
- `operator[]`:直接通过下标访问元素,不检查范围。
- `front()` 和 `back()`:分别返回第一个和最后一个元素[^2]。
- **修改元素**:
- `push_back(elem)`:在末尾添加一个元素[^1]。
- `pop_back()`:移除末尾元素[^1]。
- `insert(position, elem)`:在指定位置插入一个或多个元素。
- `erase(position)` 或 `erase(start, end)`:删除指定位置的单个或多个元素[^2]。
- **容量相关**:
- `size()`:返回当前存储的元素个数[^1]。
- `capacity()`:返回当前分配的存储空间大小[^1]。
- `empty()`:判断是否为空。
- `resize(n)`:调整容器大小为 `n`,若新增加的元素将被初始化为默认值[^1]。
- **其他操作**:
- `clear()`:清空所有元素[^1]。
- `swap(vec)`:交换两个 `vector` 的内容。
#### 3. 示例代码
以下是一个简单的 `vector` 使用示例:
```cpp
#include <iostream>
#include <vector>
int main() {
std::vector<int> vec; // 创建空 vector
vec.push_back(10); // 添加元素
vec.push_back(20);
// 访问元素
std::cout << "First element: " << vec[0] << std::endl;
std::cout << "Last element: " << vec.back() << std::endl;
// 修改元素
vec[0] = 100;
std::cout << "Modified first element: " << vec[0] << std::endl;
// 删除元素
vec.pop_back();
std::cout << "Size after pop_back: " << vec.size() << std::endl;
return 0;
}
```
阅读全文
相关推荐














