添加元素:
方法一:
insert() 插入元素到Vector中 iterator insert( iterator loc, const TYPE &val ); //在指定位置loc前插入值為val的元素,返回指向這個元素的迭代器
void insert( iterator loc, size_type num, const TYPE &val ); //在指定位置loc前插入num個值為val的元素
void insert( iterator loc, input_iterator start, input_iterator end ); //在指定位置loc前插入區間[start, end)的所有元素
方法二:
push_back() 在Vector最后添加一個元素(參數為要插入的值)
刪除元素:
方法一:
clear() 清空所有元素
empty() 判斷Vector是否為空(返回true時為空)
方法二:
erase() 刪除指定元素 (可以用指針來代替迭代器) iterator erase( iterator loc ); //要刪除元素的迭代器 iterator erase( iterator start, iterator end ); //要刪除的第一個元素的迭代器,要刪除的第二個元素的迭代器
方法三:
pop_back() 移除最后一個元素
方法四:
可以采用通用算法remove()來刪除vector容器中的元素, 不同的是,采用remove 一般情況下不會改變容器的大小,而pop_back()與erase()等成員函數會改變容器的大小。
例如:
#include "stdafx.h" #include <iostream> #include <vector> #include <algorithm> #include <string> #include <list> using namespace std; void PrintInt( const int &nData) { cout<<nData<<endl; } int _tmain( int argc, _TCHAR* argv[]) { vector< int > vecInt; for ( int i=0; i<10;++i) { vecInt.push_back(i); } cout<< " 向量中的內容為:" <<endl; for_each(vecInt.begin(),vecInt.end(),PrintInt); cout<< "vector contains " <<vecInt.size()<< " elements" <<endl; vecInt.pop_back(); // 刪除最后一個元素 cout<< " 刪除最后一個元素后,vector contains " <<vecInt.size()<< " elements" <<endl; vector< int >::iterator k = vecInt.begin(); vecInt.erase(k); // 刪除第一個元素 //vecInt.erase(k); // 迭代器k 已經失效,會出錯 cout<< " 刪除第一個元素后,vector contains " <<vecInt.size()<< " elements" <<endl; //vecInt.erase(vecInt.begin(),vecInt.end()); // 刪除所有元素 //cout<<" 刪除所有元素后,vector contains "<<vecInt.size()<<"elements"<<endl; // 輸出為0 vector< int >::iterator vecNewEnd =remove(vecInt.begin(),vecInt.end(),5); // 刪除元素 cout<< " 刪除元素后,vector contains " <<vecInt.size()<< " elements" <<endl; cout<< " 向量開始到新結束為止的元素:" <<endl; for_each(vecInt.begin(),vecNewEnd,PrintInt); cout<< " 向量中的元素:" <<endl; for_each(vecInt.begin(),vecInt.end(),PrintInt); return 0; }
結果詳見:http://www.tuicool.com/articles/eMJ3qe