c/c++ 標準順序容器 容器的訪問,刪除 操作
阿新 • • 發佈:2018-09-14
end 操作 last class 是否 name 指定位置 ont 函數
c/c++ 標準順序容器 容器的訪問,刪除 操作
pop_front:vector,string不支持
pop_back:forward_list不支持
知識點
1,front, back, at 成員函數的使用,對應代碼裏的test1
2,刪除最後一個元素pop_back, 刪除第一個元素pop_front,對應代碼裏的test2
3,刪除指定位置的元素erase,並返回下一位置的叠代器 ,對應代碼裏的test3
#include <vector> #include <string> #include <list> #include <forward_list> #include <deque> using namespace std; int main(){ //test1 順序容器的front, back(forward_list沒有back),at成員函數 //front返回容器裏的頭元素;back返回容器裏的最後一個元素 /* //在解引用一個叠代器或調用front,back之前要檢查容器裏是否有元素 deque<int> li{1,2,3,4}; if(!li.empty()){ auto val = *li.begin(); val = 9;//不會改變容器裏頭元素的值 cout << li.front() << endl; auto val2 = li.front(); val2 = 8;//不會改變容器裏頭元素的值 cout << li.front() << endl; auto& val3 = *li.begin(); val3 = 9;//會改變容器裏頭元素的值 cout << li.front() << endl; auto& val4 = li.front(); val4 = 8;//會改變容器裏頭元素的值 cout << li.front() << endl; auto val5 = li.end(); //得到容器的最後一個元素 auto last = *(--val5); cout << last << endl; auto v = li.at(1); auto v1 = li[2]; cout << v << " " << v1 << endl; } */ //test2 pop_back, pop_front //pop_back:刪除容器的最後一個元素;pop_front:刪除容器的第一個元素 /* list<int> li{1,2,3,4}; if(!li.empty()){ li.pop_back(); cout << li.back() << endl; li.pop_front(); cout << li.front() << endl; } */ //test3 erase //刪除指定位置的元素,並放回指向刪除元素的下一個元素的叠代器 vector<int> li{0,1,2,3,4,5,6,7,8}; //刪除奇數 auto b = li.begin(); while(b != li.end()){ if(*b % 2){ b = li.erase(b); } else{ ++b; } } for(auto const &s : li){ cout << s << " "; } cout << endl; auto it = li.begin(); li.erase(it, it + 2); for(auto const &s : li){ cout << s << " "; } cout << endl; }
c/c++ 學習互助QQ群:877684253
本人微信:xiaoshitou5854
c/c++ 標準順序容器 容器的訪問,刪除 操作