vector
是 C++ 標準庫中的一個動態數組類,它可以在運行時自動調整大小,非常適合用于處理大小不確定的集合。下面是 vector
的常見用法示例,幫助你更好地理解如何使用它。
注意:所有用數組完成的任務都可以用vector完成。
1.?引入頭文件
首先,你需要引入 vector
的頭文件:
#include <vector>
2.?定義和初始化?vector
vector
可以通過幾種方式進行初始化:
#include <iostream>
#include <vector>
using namespace std;int main() {// 1. 默認構造一個空的 vectorvector<int> v1; // 2. 使用初始化列表初始化vector<int> v2 = {1, 2, 3, 4};// 3. 指定大小并初始化所有元素為0vector<int> v3(5, 0); // 長度為5,所有元素初始化為0// 4. 使用其他 vector 初始化vector<int> v4(v2); // 復制v2return 0;
}
3.?訪問元素
vector
允許通過下標或迭代器訪問元素,類似于數組。
cout << v2[0] << endl; // 訪問第一個元素
cout << v2.at(1) << endl; // 使用 at() 方法(有越界檢查)
4.?增加元素
使用 push_back()
可以向 vector
添加元素到末尾。
vector<int> v = {1, 2, 3};
v.push_back(4); // 向末尾添加元素 4
cout << v[3] << endl; // 輸出 4
5.?刪除元素
pop_back()
用于刪除 vector
中的最后一個元素。
v.pop_back(); // 刪除最后一個元素
如果你需要刪除 vector
中的某個特定位置的元素,可以使用 erase()
方法:
v.erase(v.begin() + 1); // 刪除索引1的元素? ?注意:索引=下標,索引1為第二個元素
6.?調整大小
resize()
方法用于調整 vector
的大小,可以縮小或擴展。
v.resize(5); // 將大小調整為 5(擴展或截斷)
7.?插入元素
insert()
方法可以在 vector
的任意位置插入元素。
v.insert(v.begin() + 1, 99); // 在索引1的位置插入 99
8.?遍歷元素
vector
支持使用迭代器進行遍歷:
for (vector<int>::iterator it = v.begin(); it != v.end(); ++it) {cout << *it << " ";
}
cout << endl;
或者使用范圍 for
循環(C++11 起支持):
for (int x : v) {cout << x << " ";
}
cout << endl;
9.?獲取大小
你可以使用 size()
方法獲取 vector
中元素的數量:
cout << "Size: " << v.size() << endl;
10.?檢查是否為空
使用 empty()
方法可以檢查 vector
是否為空。
if (v.empty()) {cout << "Vector is empty" << endl;
} else {cout << "Vector is not empty" << endl;
}
11.?容量管理
capacity()
方法返回 vector
當前的容量(實際分配的內存大小),可能大于實際的元素個數。你可以使用 reserve()
來增加 vector
的容量,避免多次擴容導致性能開銷。
cout << "Capacity: " << v.capacity() << endl;
v.reserve(20); // 預先為 20 個元素分配空間
12.?清空元素
如果你想刪除所有元素,可以使用 clear()
方法:
v.clear(); // 刪除所有元素
完整示例
#include <iostream>
#include <vector>
using namespace std;int main() {vector<int> v = {1, 2, 3};// 向 vector 中添加元素v.push_back(4);v.push_back(5);// 遍歷輸出元素for (int x : v) {cout << x << " "; // 輸出 1 2 3 4 5}cout << endl;// 刪除最后一個元素v.pop_back();// 插入元素v.insert(v.begin() + 1, 99); // 在索引1的位置插入 99// 輸出修改后的 vectorfor (int x : v) {cout << x << " "; // 輸出 1 99 2 3 4}cout << endl;// 獲取大小和容量cout << "Size: " << v.size() << endl; // 輸出 5cout << "Capacity: " << v.capacity() << endl; // 輸出當前容量// 清空 vectorv.clear();cout << "Size after clear: " << v.size() << endl; // 輸出 0return 0;
}