一、vector介紹
vector是c++ STL(Standard Template Library)中的一個容器,它能夠動態地增加或減少容器的大小,並且支持快速的隨機訪問。vector是一個模板類,所以可以存儲任意類型的數據。
#include <vector>
using namespace std;
vector<int> v; //定義一個存儲int類型的vector
二、vector的構造函數
vector還有一些構造函數,可以幫助我們更方便地創建vector,常用的構造函數如下:
(1)無參構造函數:vector()。創建一個空的vector。
(2)帶參構造函數:vector(n, x)。創建一個大小為n的vector,每個元素的值都為x。
(3)帶參構造函數:vector(iterator first, iterator last)。用[first, last)區間中的元素創建一個新的vector。
//創建一個大小為10的vector,每個元素的值都是3
vector<int> v1(10, 3);
//從數組a中的第2個元素開始,到第5個元素結束,創建一個新的vector
int a[] = {1, 2, 3, 4, 5};
vector<int> v2(a+1, a+5);
三、vector的方法和操作
vector提供了很多方法和操作,下面將一一介紹:
1.添加和刪除元素
(1)push_back(x):向vector尾部添加一個元素x。
(2)pop_back():刪除vector尾部的一個元素。
//給vector添加元素
v.push_back(10); //添加一個元素10
v.push_back(20); //添加一個元素20
//刪除vector尾部的一個元素
v.pop_back();
2.訪問元素
(1)operator[]:可以像訪問數組一樣訪問vector中的元素。
(2)at(i):訪問vector中下標為i的元素,如果下標越界,會拋出一個out_of_range異常。
//訪問vector中的元素
v[0] = 5; //將第一個元素賦值為5
v[1] = 6; //將第二個元素賦值為6
//訪問vector中的元素並修改
cout << v.at(0) << endl; //輸出第一個元素的值
cout << v.at(1) << endl; //輸出第二個元素的值
3.查找和排序
(1)find(x):查找vector中是否存在一個元素x,如果找到了,返回該元素的迭代器;如果沒有找到,返回vector的尾迭代器end()。
(2)sort():將vector中的元素按照從小到大的順序排序。
//查找vector中某個元素
if (find(v.begin(), v.end(), 10) != v.end())
cout << "Found!" << endl;
else
cout << "Not found!" << endl;
//對vector中的元素進行排序
sort(v.begin(), v.end());
4.其他操作
(1)size():返回vector中元素的個數。
(2)empty():判斷vector是否為空,如果為空返回true,否則返回false。
(3)clear():刪除vector中所有的元素。
//輸出vector的元素個數
cout << v.size() << endl;
//判斷vector是否為空
if (v.empty())
cout << "Vector is empty." << endl;
else
cout << "Vector is not empty." << endl;
//刪除vector中的元素
v.clear();
四、實戰演示
下面是使用vector實現一個數組的例子。
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> v(10, 0); //創建一個大小為10的vector,元素初始值為0
for (int i = 0; i < v.size(); i++)
v[i] = i + 1; //給vector中的元素賦值
for (int i = 0; i < v.size(); i++)
cout << v[i] << " "; //輸出vector中的元素
return 0;
}
五、總結
本文詳細介紹了c++ STL中的vector頭文件的使用方法和常見操作,vector是一個非常實用的容器,在c++開發中經常會用到,希望本文對大家學習和使用vector有所幫助。
原創文章,作者:QWBRA,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/372493.html