當前位置:
首頁 >
续vector
發布時間:2025/4/16
29
豆豆
//c.push_back(elem)在尾部插入一個elem數據。
vector<int> v;
v.push_back(1);
//c.pop_back()刪除末尾的數據。vector<int> v;v.pop_back();//c.assign(beg,end)將[beg,end)一個左閉右開區間的數據賦值給c。
vector<int> v1,v2;
v1.push_back(10);
v1.push_back(20);
v2.push_back(30);
v2.assign(v1.begin(),v1.end());
//c.assign (n,elem)將n個elem的拷貝賦值給c。
vector<int> v;
v.assign(5,10);//往v里放5個10,默認為從v.begin()開始放,則會把原先v容器中的值給覆蓋掉//c.at(int index)傳回索引為index的數據,如果index越界,拋出out_of_range異常。下標從0開使
vecto<int> v;
cout << v.at(2) << endl;//打印vector中下標是2的數據
//c.begin()返回指向第一個數據的迭代器。
//c.end()返回指向最后一個數據之后的迭代器。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
vector<int>::iterator it;
for(it = v.begin();it!=v.end();it++)cout << *it << "\t";cout << endl;
//c.rbegin()返回逆向隊列的第一個數據,即c容器的最后一個數據。
//c.rend()返回逆向隊列的最后一個數據的下一個位置,即c容器的第一個數據再往前的一個位置。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
vector<int>::reverse_iterator it;
for(it = v.rbegin();it!=v.rend();it++)cout << *it << "\t";
cout << endl;
//c.capacity()返回容器中數據個數,翻倍增長。
vector<int> v;
v.push_back(1);
cout << v.capacity() << endl; // 1
v.push_back(2);
cout << v.capacity() << endl; // 2
v.push_back(3);
cout << v.capacity() << endl; // 4
//c.clear()移除容器中的所有數據。
vector<int>::iterator it;
for(it = v.begin();it!=v.end();it++)cout << *it << "\t";
v.clear();
for(it = v.begin();it!=v.end();it++)cout << *it << "\t";
cout << endl;
//c.empty()判斷容器是否為空。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
if(!v.empty())cout << "v is not empty!" << endl;
//c.erase(pos)刪除pos位置的數據,傳回下一個數據的位置。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.erase(v.begin());
//c.erase(beg,end)刪除[beg,end)區間的數據,傳回下一個數據的位置。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
v.erase(v.begin(),v.end());
//c.front()返回第一個數據。
//c.back()傳回最后一個數據,不檢查這個數據是否存在。
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(3);
if(!vec.empty())cout << “the first number is:” << v.front() << endl;cout << “the last number is:” << v.back() << endl;
//c.insert(pos,elem) 在pos位置插入一個elem的拷貝,返回插入的值的迭代器。
//c.insert(pos,n,elem)在pos位置插入n個elem的數據,無返回值。
//c.insert(pos,beg,end)在pos位置插入在[beg,end)區間的數據,無返回值。
vector<int> v;
v.insert(v.begin(),10);
v.insert(v.begin(),2,20);
v.insert(v.begin(),v1.begin(),v1.begin()+2);/*c.size()返回容器中實際數據的個數。
c.resize(num)重新指定隊列的長度。(往往用來增加vector的長度,小->大 ok 大->小 沒用!)
c.reserve()保留適當的容量。
針對resize()和reserver()做一點分析:reserve是容器預留空間,但并不真正創建元素對象,在創建對象之前,不能引用容器內的元素,因此當加入新的元素時,需要用push_back()/insert()函數。resize是改變容器的大小,并且創建對象,因此,調用這個函數之后,就可以引用容器內的對象了,因此當加入新的元素時,用operator[]操作符,或者用迭代器來引用元素對象。再者,兩個函數的形式是有區別的,reserve函數之后一個參數,即需要預留的容器的空間;resize函數可以有兩個參數,第一個參數是容器新的大小,第二個參數是要加入容器中的新元素,如果這個參數被省略,那么就調用元素對象的默認構造函數。reserve只是保證vector的空間大小(capacity)最少達到它的參數所指定的大小n。在區間[0, n)范圍內,如果下標是index,vector[index]這種訪問有可能是合法的,也有可能是非法的,視具體情況而定。resize和reserve接口的共同點是它們都保證了vector的空間大小(capacity)最少達到它的參數所指定的大小。
c.max_size()返回容器能容量的最大數量。*///c1.swap(c2)將c1和c2交換。
//swap(c1,c2)同上。
vector<int> v1,v2,v3;
v1.push_back(10);
v2.swap(v1);
swap(v3,v1);
/*
vector<type>c;創建一個空的vector容器。
vector<type> c1(c2);復制一個vector。
vector<type> c(n);創建一個vector,含有n個數據,數據均以缺省構造產生,即全0;
vector<type> c(n,elem)創建一個vector,含有n個elem的拷貝數據。
vector<type> c(beg,end)創建一個以[beg,end)區間的vector。
~vector<type>() 銷毀所有數據,施放內存。
*/
自:http://www.cnblogs.com/scandy-yuan/archive/2013/01/07/2849735.html
總結