C++vector的用法你都知道嘛
更新時間:2022年02月18日 11:51:49 作者:菜雞圣龍進化菜松鼠
這篇文章主要為大家詳細介紹了C++中vector的用法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
C++vector 用法整理
1.頭文件
#include<iostream>//容器 #include<vector> //算法 #include<iterator>//迭代器
一個代碼示例
#include<iostream>//容器
#include<vector> //算法
#include<iterator>//迭代器
using namespace std;
int main(int argc, const char* argv[])
{
const int SIZE = 6;
int array[SIZE] = {1,2,3,4,5,6};
vector<int> v(array,array+SIZE);
cout<<"First element:"<<v.front()<<"\n Last element"<<v.back()<<endl;
}
2.vector初始化
定義十個整形元素的向量(其中初值不確定)
vector<int> a(10);
每個元素初值為1;
vector<int> a(10,1);
類似于深拷貝的整體賦值方式
vector<char> a(b); vector<char> a(b.begin(),b.begin+3);//(a的值為0~2個元素)
用數(shù)組賦初值(和上面一個有點相似)
vector<int> a(b, b+7);
3.vector對象的重要操作
1.賦值(assign)
a.assign(b.begin(),b.begin()+3); //注意!此處,將b 0~2個元素構成的向量賦值給a!與上面不同! a.assign(4,2);// 與vector<int> a(10,1);結果相同
2.返回元素值
//返回最后一個元素 a.back(); //返回第一個元素 a.front(); //數(shù)組返回式 a[i];
3.清空、判斷是否為空
a.clear(); a.empty();
4.刪除
//刪除最后一個元素 a.pop_back(); //刪除一塊元素 a.erase(a.begin(),a.begin()+3);
5.插入
//在最后一個向量后插入一個元素
a.push_back(5);
// 插入一段元素(從第一個元素算起,插入3個數(shù),值都為5)
a.insert(a.begin(), 3, 5);
//用數(shù)組插入一段元素(在a的第一個元素的位置插入b的第3個元素到第5個元素)
a.insert(a.begin(), b+1,b+6);
//從現(xiàn)有向量中選擇元素向向量中添加
int a[6] = {1, 2, 3, 4, 5, 6};
vector<int> b;
wector<int> c(a, a+4);
for(vector<int>::iterator it = c.begin(); it<c.end():it++)
{
b.push_back(*it);
}
//從文件讀取元素向向量中添加
ifstream in("data.txt");
vector<int> a;
for(int i;in>>i)
{
a.push_back(i);
}
6.返回vector的現(xiàn)存元素個數(shù)、共可容納個數(shù)
a.size(); a.c apacity();
7.調整元素個數(shù)(這個好牛)
//將元素個數(shù)調整至10,多刪少補,補的值隨機 a.resize(10); //將元素個數(shù)調整至10,多刪少補,補的值為2 a.resize(10,2); //大容量擴充(不補充值) a.reserve(100);
8.整體性交換
a.swap(b);
9.向量的比較操作
a==b; //還有 != >= <= > <
10.重要算法
//從小到大排列 sort(a.begin(), a.end()); //倒置但不排列 reverse(a.begin(),a.end()); //元素復制 copy(a.begin(),a.end(),b.begin()); //從某一區(qū)塊中查找元素值,返回位置 find(a.begin(),a.end(),10);
4.一些誤區(qū)
下標只能獲取已存在的元素,不能進行賦值操作
//錯誤示例
vector<int> a;
for(int i = 0;i<10;i++)
a[i] = i;
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能
LibCurl是一個開源的免費的多協(xié)議數(shù)據(jù)傳輸開源庫,該框架具備跨平臺性,開源免費,并提供了包括HTTP、FTP、SMTP、POP3等協(xié)議的功能,本文將給大家介紹C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能2023-11-11
C語言實現(xiàn)食堂就餐管理系統(tǒng)(帶鏈表)
這篇文章主要為大家詳細介紹了C語言實現(xiàn)食堂就餐管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11
C語言中auto,register,static,const,volatile的區(qū)別詳細解析
以下是對C語言中auto,register,static,const,volatile的區(qū)別進行了詳細的分析介紹,需要的朋友可以過來參考下2013-09-09
MySQL系列教程之使用C語言來連接數(shù)據(jù)庫
c語言操作Mysql數(shù)據(jù)庫,主要就是為了實現(xiàn)對數(shù)據(jù)庫的增、刪、改、查等操作,下面這篇文章主要給大家介紹了關于MySQL系列教程之使用C語言來連接數(shù)據(jù)庫的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09
C++中的opeartor?new和placement?new使用步驟
這篇文章主要介紹了C++中的opeartor?new和placement?new詳解,在很多情況下,placement?new的使用方法和其他普通的new有所不同。這里提供了它的使用步驟,需要的朋友可以參考下2022-10-10

