函数 | 功能 |
---|---|
pop_back() | 删除 vector 容器中最后一个元素,该容器的大小(size)会减 1,但容量(capacity)不会发生改变。 |
erase(pos) | 删除 vector 容器中 pos 迭代器指定位置处的元素,并返回指向被删除元素下一个位置元素的迭代器。该容器的大小(size)会减 1,但容量(capacity)不会发生改变。 |
swap(beg)、pop_back() | 先调用 swap() 函数交换要删除的目标元素和容器最后一个元素的位置,然后使用 pop_back() 删除该目标元素。 |
erase(beg,end) | 删除 vector 容器中位于迭代器 [beg,end)指定区域内的所有元素,并返回指向被删除区域下一个位置元素的迭代器。该容器的大小(size)会减小,但容量(capacity)不会发生改变。 |
remove() | 删除容器中所有和指定元素值相等的元素,并返回指向最后一个元素下一个位置的迭代器。值得一提的是,调用该函数不会改变容器的大小和容量。 |
clear() | 删除 vector 容器中所有的元素,使其变成空的 vector 容器。该函数会改变 vector 的大小(变为 0),但不是改变其容量。 |
#include <vector> #include <iostream> using namespace std; int main() { vector<int>demo{ 1,2,3,4,5 }; demo.pop_back(); //输出 dmeo 容器新的size cout << "size is :" << demo.size() << endl; //输出 demo 容器新的容量 cout << "capacity is :" << demo.capacity() << endl; for (int i = 0; i < demo.size(); i++) { cout << demo[i] << " "; } return 0; }运行结果为:
size is :4
capacity is :5
1 2 3 4
iterator erase (pos);
其中,pos 为指定被删除元素位置的迭代器,同时该函数会返回一个指向删除元素所在位置下一个位置的迭代器。#include <vector> #include <iostream> using namespace std; int main() { vector<int>demo{ 1,2,3,4,5 }; auto iter = demo.erase(demo.begin() + 1);//删除元素 2 //输出 dmeo 容器新的size cout << "size is :" << demo.size() << endl; //输出 demo 容器新的容量 cout << "capacity is :" << demo.capacity() << endl; for (int i = 0; i < demo.size(); i++) { cout << demo[i] << " "; } //iter迭代器指向元素 3 cout << endl << *iter << endl; return 0; }运行结果为:
size is :4
capacity is :5
1 3 4 5
3
例如:注意,swap() 函数在头文件
<algorithm>
和<utility>
中都有定义,使用时引入其中一个即可。
#include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { vector<int>demo{ 1,2,3,4,5 }; //交换要删除元素和最后一个元素的位置 swap(*(std::begin(demo)+1),*(std::end(demo)-1));//等同于 swap(demo[1],demo[4]) //交换位置后的demo容器 for (int i = 0; i < demo.size(); i++) { cout << demo[i] << " "; } demo.pop_back(); cout << endl << "size is :" << demo.size() << endl; cout << "capacity is :" << demo.capacity() << endl; //输出demo 容器中剩余的元素 for (int i = 0; i < demo.size(); i++) { cout << demo[i] << " "; } return 0; }运行结果为:
1 5 3 4 2
size is :4
capacity is :5
1 5 3 4
iterator erase (iterator first, iterator last);
其中 first 和 last 是指定被删除元素区域的迭代器,同时该函数会返回指向此区域之后一个位置的迭代器。#include <vector> #include <iostream> using namespace std; int main() { std::vector<int> demo{ 1,2,3,4,5 }; //删除 2、3 auto iter = demo.erase(demo.begin()+1, demo.end() - 2); cout << "size is :" << demo.size() << endl; cout << "capacity is :" << demo.capacity() << endl; for (int i = 0; i < demo.size(); i++) { cout << demo[i] << " "; } return 0; }运行结果为:
size is :3
capacity is :5
1 4 5
<algorithm>
头文件中。例如:
#include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { vector<int>demo{ 1,3,3,4,3,5 }; //交换要删除元素和最后一个元素的位置 auto iter = std::remove(demo.begin(), demo.end(), 3); cout << "size is :" << demo.size() << endl; cout << "capacity is :" << demo.capacity() << endl; //输出剩余的元素 for (auto first = demo.begin(); first < iter;++first) { cout << *first << " "; } return 0; }运行结果为:
size is :6
capacity is :6
1 4 5
另外还可以看到,既然通过 remove() 函数删除掉 demo 容器中的多个指定元素,该容器的大小和容量都没有改变,其剩余位置还保留了之前存储的元素。我们可以使用 erase() 成员函数删掉这些 "无用" 的元素。remove() 的实现原理是,在遍历容器中的元素时,一旦遇到目标元素,就做上标记,然后继续遍历,直到找到一个非目标元素,即用此元素将最先做标记的位置覆盖掉,同时将此非目标元素所在的位置也做上标记,等待找到新的非目标元素将其覆盖。因此,如果将上面程序中 demo 容器的元素全部输出,得到的结果为
1 4 5 4 3 5
。
#include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { vector<int>demo{ 1,3,3,4,3,5 }; //交换要删除元素和最后一个元素的位置 auto iter = std::remove(demo.begin(), demo.end(), 3); demo.erase(iter, demo.end()); cout << "size is :" << demo.size() << endl; cout << "capacity is :" << demo.capacity() << endl; //输出剩余的元素 for (int i = 0; i < demo.size();i++) { cout << demo[i] << " "; } return 0; }运行结果为:
size is :3
capacity is :6
1 4 5
remove()用于删除容器中指定元素时,常和 erase() 成员函数搭配使用。
#include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { vector<int>demo{ 1,3,3,4,3,5 }; //交换要删除元素和最后一个元素的位置 demo.clear(); cout << "size is :" << demo.size() << endl; cout << "capacity is :" << demo.capacity() << endl; return 0; }运行结果为:
size is :0
capacity is :6
Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有 粤ICP备16019765号
广州京杭网络科技有限公司 版权所有