STL 容器和迭代器连载6_顺序容器的操作3
生活随笔
收集整理的這篇文章主要介紹了
STL 容器和迭代器连载6_顺序容器的操作3
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
2019獨角獸企業(yè)重金招聘Python工程師標準>>>
/*- ========================================================== * 文件名 :STL_con_ite_6.cpp * 開發(fā)人員:袁培榮 * 當前版本:1.0.0.2595 * 創(chuàng)建時間:2012-05-24 * 修改時間:2012-05-24 * 功能說明:STL 容器和迭代器連載6_順序容器的操作3 * 版權(quán)說明:版權(quán)所有 袁培榮 YuanPeirong * 編譯環(huán)境:Windows 7(x64) SP1 簡體中文專業(yè)版 * 編譯器: Visual Studio 2010 SP1(中文旗艦版)MinGW 20120426 GNU GCC 4.6.2Visual C++ 6.0 SP6(中文企業(yè)版) - ==========================================================*/#include <iostream> #include <vector> #include <list> #include <deque> #include <string>using std::cout; using std::endl; using std::vector; using std::list; using std::deque; using std::string;int main(int argc, char* argv[]) {//下面來介紹刪除容器內(nèi)元素的相關(guān)操作//先定義一個容器,并添加101個元素。vector<int> v1;for(int i=0; i!=101; i++) //C++程序員習慣于用i!=101,而不是i<101v1.push_back(i);cout<<"在所有刪除操作前v1.size()="<<v1.size()<<endl;//第一種方法://erase(p) :刪除迭代器p所指向的元素//返回指向被刪除元素的下一位置的迭代器。//注意:p必須真實地指向?qū)嶋H存在的元素。cout<<"第一種方法:"<<endl;cout<<"刪除前v1的第96個元素值是(方法1輸出):"<<*(v1.begin()+95)<<endl;cout<<"刪除前v1的第96個元素值是(方法2輸出):"<<v1[95]<<endl;//我們把第96個元素刪除vector<int>::iterator iter1=v1.erase(v1.begin()+95);//驗證:cout<<"刪除后v1.size()="<<v1.size()<<endl;cout<<"刪除后v1的第96個元素值是(方法1輸出):"<<*iter1<<endl;cout<<"刪除后v1的第96個元素值是(方法2輸出):"<<v1[95]<<endl;//第二種方法://erase(b,e) :刪除迭代器b,e所指向的元素形成的左閉合區(qū)間//返回指向被刪除的最后一個元素的下一位置的迭代器。cout<<"第二種方法:"<<endl;cout<<"刪除前v1的第81個元素值是:"<<*(v1.begin()+80)<<endl;cout<<"刪除前v1的第82個元素值是:"<<*(v1.begin()+81)<<endl;cout<<"刪除前v1的第83個元素值是:"<<*(v1.begin()+82)<<endl;//我們把第81,82,83三個元素刪除iter1=v1.erase(v1.begin()+80, v1.begin()+83);//驗證:cout<<"刪除后v1.size()="<<v1.size()<<endl;cout<<"刪除后v1的第81個元素值是(方法1輸出):"<<*iter1<<endl;cout<<"刪除后v1的第81個元素值是(方法2輸出):"<<*(v1.begin()+80)<<endl;cout<<"刪除后v1的第82個元素值是:"<<*(v1.begin()+81)<<endl;cout<<"刪除后v1的第83個元素值是:"<<*(v1.begin()+82)<<endl;//第三種方法://pop_back() 刪除容器的最后一個元素,返回void類型cout<<"第三種方法:"<<endl;cout<<"刪除前v1的最后一個元素值是:"<<*(v1.end()-1)<<endl;if(v1.size()!=0) //防止容器為空時,刪除操作引發(fā)錯誤v1.pop_back();//驗證:cout<<"刪除后v1.size()="<<v1.size()<<endl;cout<<"刪除后v1的最后一個元素值是:"<<*(v1.end()-1)<<endl;//第四種方法://pop_front() 刪除容器的第一個元素,返回void類型//值得注意的是,這種方法只能用于list和deque容器list<int> l1(3,0);*l1.begin()=0; //為便于區(qū)分元素,將各修改成不相同//下面指出修改list容器的元素時的兩種錯誤//l1[1]=1; //list容器不支持l1[0]這樣的下標訪問(下面會講)//*(l1.begin()+2)=2; //list容器的迭代器不能與數(shù)值相加(復習一下前面)list<int>::iterator iter2=l1.begin();iter2++; //迭代器的++操作是對所有容器都支持的*(iter2)=1;iter2++;*(iter2)=2;cout<<"第四種方法:"<<endl;cout<<"刪除前l(fā)1.size()="<<l1.size()<<endl;cout<<"刪除前l(fā)1的第一個元素值是:"<<*l1.begin()<<endl;if(!l1.empty()) //防止容器為空時,刪除操作引發(fā)錯誤l1.pop_front(); //empty()用來判斷容器是否為空,下面會講//驗證:cout<<"刪除后l1.size()="<<l1.size()<<endl;cout<<"刪除后l1的第一個元素值是:"<<*l1.begin()<<endl;//雖然第四種方法pop_front(t)只支持list和deque容器//但我們用第一種方法的一個特例就能和做到第二種方法同樣的效果://例如:cout<<"用第一種方法的特例實現(xiàn)第四種方法:"<<endl;cout<<"刪除前v1.size()="<<v1.size()<<endl;cout<<"刪除前v1的第一個元素值是:"<<*v1.begin()<<endl;v1.erase(v1.begin());//驗證:cout<<"刪除后v1.size()="<<v1.size()<<endl;cout<<"刪除后v1的第一個元素值是:"<<*v1.begin()<<endl;//這樣,我們可以為不支持第四種方法的容器擴展這一種方法//第五種方法://clear() 刪除容器內(nèi)的所有元素,返回void類型cout<<"第五種方法:"<<endl;cout<<"清空前v1.size()="<<v1.size()<<endl;cout<<"清空前l(fā)1.size()="<<l1.size()<<endl;//清空v1和l1v1.clear();l1.clear();//驗證:cout<<"清空后v1.size()="<<v1.size()<<endl;cout<<"清空后l1.size()="<<l1.size()<<endl;return 0; }//============================ //運行結(jié)果: //============================ // 在所有刪除操作前v1.size()=101 // 第一種方法: // 刪除前v1的第96個元素值是(方法1輸出):95 // 刪除前v1的第96個元素值是(方法2輸出):95 // 刪除后v1.size()=100 // 刪除后v1的第96個元素值是(方法1輸出):96 // 刪除后v1的第96個元素值是(方法2輸出):96 // 第二種方法: // 刪除前v1的第81個元素值是:80 // 刪除前v1的第82個元素值是:81 // 刪除前v1的第83個元素值是:82 // 刪除后v1.size()=97 // 刪除后v1的第81個元素值是(方法1輸出):83 // 刪除后v1的第81個元素值是(方法2輸出):83 // 刪除后v1的第82個元素值是:84 // 刪除后v1的第83個元素值是:85 // 第三種方法: // 刪除前v1的最后一個元素值是:100 // 刪除后v1.size()=96 // 刪除后v1的最后一個元素值是:99 // 第四種方法: // 刪除前l(fā)1.size()=3 // 刪除前l(fā)1的第一個元素值是:0 // 刪除后l1.size()=2 // 刪除后l1的第一個元素值是:1 // 用第一種方法的特例實現(xiàn)第四種方法: // 刪除前v1.size()=96 // 刪除前v1的第一個元素值是:0 // 刪除后v1.size()=95 // 刪除后v1的第一個元素值是:1 // 第五種方法: // 清空前v1.size()=95 // 清空前l(fā)1.size()=2 // 清空后v1.size()=0 // 清空后l1.size()=0 //============================轉(zhuǎn)載于:https://my.oschina.net/u/186539/blog/59452
總結(jié)
以上是生活随笔為你收集整理的STL 容器和迭代器连载6_顺序容器的操作3的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Drupal] How to get
- 下一篇: [转载]C#异步委托的用法 .