資料結構-練習 18 vector && list

來源:互聯網
上載者:User
vector的用法

vector包括的函數為:

英文解析:http://www.cplusplus.com/reference/stl/

寫了一段程式,測試一下幾個常用的函數:

#include<iostream>#include<vector>#include<list>#include<deque>using namespace std;int main(){//初始化vector<int> a(3,7);cout<<"輸出元素";///迭代器for(vector<int>::iterator itr=a.begin();itr<a.end();++itr)  cout<<*itr;  cout<<endl;//測試是否為空白 empty()if(!a.empty())cout<<"此容器的大小為:"<<a.capacity()<<"含有元素為:"<<a.size();elsecout<<"元素為空白";cout<<endl;//清楚元素clear()a.clear();if(!a.empty())  cout<<"容器裡的元素被clear()清理完畢"<<endl;//調整容器的大小 resizea.resize(5);cout<<"此容器的大小重新調整為:"<<a.capacity()<<endl;cout<<"預設的5個元素大小為:";for(vector<int>::iterator it=a.begin();it<a.end();++it)  cout<<*it;a.push_back(3);a.push_back(4);//返回第一個元素cout<<"返回第一個元素"<<a.front()<<",此時容器的capacity為:"<<a.capacity()<<"可見push_back 只是在末尾增加元素";cout<<endl<<"通過at擷取元素"<<a.at(5)<<endl;//pop返回a.pop_back();cout<<"pop_back後,容器的大小為:"<<a.capacity()<<"元素的個數為:"<<a.size()<<endl<<"輸出元素";for(vector<int>::iterator it=a.begin();it<a.end();++it)  cout<<*it;cout<<endl<<"由此可見,pop_back只彈出元素,不返回"<<endl;a.assign(4,5);//不會改變capacity,會改變sizecout<<"capacity:"<<a.capacity()<<endl;;a[0]=2;cout<<"顯示第0個和第3個位置的元素,驗證[]和assign的賦值功能:"<<a[0]<<","<<a[3];cout<<"front()返回最後一個元素"<<a.back();vector<int>::iterator it=a.begin();a.erase(it);cout<<"erase後的元素為:";for(vector<int>::iterator it=a.begin();it<a.end();++it)  cout<<*it;a.swap(vector<int>());return 0;}

測試結果

 

list的用法

與vector相比,list沒有capacity,原因是因為:list不需要對記憶體重新全部分配,list用鏈表的,每增加一個元素都要新開闢一個元素,然後插入到list中,記住list是雙鏈表。list多了一個pash_front和pop_front。

分析的英文串連:http://www.cplusplus.com/reference/list/list/merge/

#include<list>#include<iostream>using namespace std;int main(){//定義LISTINTtypedef list<int> LISTINT;typedef list<char> LISTCHAR;LISTINT list_int(3);list_int.assign(4,5);list_int.push_back(6);list_int.push_front(10);list_int.push_front(1);list_int.pop_front();list_int.pop_back();list_int.push_back(6);for(LISTINT::iterator itr=list_int.begin();itr!=list_int.end();++itr)   cout<<*itr<<",";  cout<<endl;for(LISTINT::reverse_iterator itr=list_int.rbegin();itr!=list_int.rend();++itr)   cout<<*itr<<",";   cout<<endl;list_int.erase(--list_int.end());list_int.sort();for(LISTINT::iterator itr=list_int.begin();itr!=list_int.end();++itr)   cout<<*itr<<",";return 0;}

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.