淺談C++STL之雙端隊(duì)列容器
概述
deque塊在頭部和尾部都可以插入和刪除。而不需要移動(dòng)任何元素,而不需要移動(dòng)其他元素(使用push_back()方法在尾部插入元素,會(huì)擴(kuò)張隊(duì)列,而使用push_front()方法在首部插入元素和使用insert()方法在中間插入元素,只是將原位置上的元素進(jìn)行覆蓋,不會(huì)增加新元素)一般來說,當(dāng)考慮到容器元素的內(nèi)存分配策略和操作的性能時(shí)deque相當(dāng)于vector更有優(yōu)勢。
創(chuàng)建deque對象與vector類似
插入元素
使用push_back()方法從尾部插入元素,會(huì)不斷擴(kuò)張隊(duì)列。
#include<iostream> #include<deque> using namespace std; int main() { deque<int> d; d.push_back(1); d.push_back(2); cout<<d[0]<<" : "<<d[1]<<endl; return 0; }
從頭部插入元素,不會(huì)增加新元素,只將原來有的元素覆蓋。
#include<iostream> #include<deque> using namespace std; int main() { deque<int> d; d.push_back(1); d.push_back(2); d.push_back(3); d.push_front(10);//d.insert(d.begin()+1, 10); d.push_front(20);//d.insert(d.begin()+2, 20); cout<<d[0]<<" "<<d[1]<<" "<<d[2]<<endl; return 0; }
遍歷
#include<iostream> #include<deque> using namespace std; int main() { deque<int> d; d.push_back(1); d.push_back(2); d.push_back(3); for(int i = 0; i < d.size(); i ++) cout<<d[i]<<" "; cout<<endl; deque<int>::iterator it; for(it = d.begin(); it != d.end(); it ++) cout<<*it<<" "; cout<<endl; deque<int>::reverse_iterator rit; for(rit = d.rbegin(); rit != d.rend(); rit ++) cout<<*rit<<" "; cout<<endl; return 0; }
刪除元素
可以從雙端隊(duì)列的手部,尾部,中部刪除元素,并可以清空雙端隊(duì)列容器
#include<iostream> #include<deque> using namespace std; int main() { deque<int> d; for(int i = 1; i < 6; i ++) d.push_back(i); d.pop_front(); d.pop_front(); deque<int>::iterator it; for(it = d.begin(); it != d.end(); it ++) cout<<*it<<" "; cout<<endl; d.pop_back(); for(it = d.begin(); it != d.end(); it ++) cout<<*it<<" "; cout<<endl; d.erase(d.begin()+1); for(it = d.begin(); it != d.end(); it ++) cout<<*it<<" "; cout<<endl; d.clear(); cout<<d.size()<<endl; return 0; }
以上就是淺談C++STL之雙端隊(duì)列容器的詳細(xì)內(nèi)容,更多關(guān)于C++STL之雙端隊(duì)列容器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)鄰接表
這篇文章主要為大家詳細(xì)介紹了C++數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)鄰接表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04C語言入門篇--四大常量(字面,const修飾,宏,枚舉)及標(biāo)識(shí)符
本篇文章是c語言基礎(chǔ)篇,主要講述一下常量,常量即不可被直接修改的量(const修飾的常變量可間接修改,后續(xù)文章會(huì)繼續(xù)說明)請大家持續(xù)關(guān)注腳本之家2021-08-08