C++ Deque 库 - erase() 函数
描述
C++ 函数 std::deque::erase() 从双端队列中删除单个元素并将大小减小一。
声明
以下是 std::deque::erase() 函数形式的声明 std::deque 标头。
C++98
iterator erase (iterator position);
C++11
iterator erase (const_iterator position );
参数
position − 迭代器指向双端队列元素。
返回值
返回一个随机访问迭代器,它指向删除元素的位置。
异常
如果位置无效,则行为 undefined。
时间复杂度
线性,即 O(n)
示例
以下示例显示了 std::deque::erase() 函数的用法。
#include <iostream>
#include <deque>
using namespace std;
int main(void) {
deque<int> d = {1, 2, 3, 4, 5};
cout << "Contents of deque before erase operation" << endl;
for (auto it = d.begin(); it != d.end(); ++it)
cout << *it << endl;
d.erase(d.begin());
cout << "Contents of deque after erase operation" << endl;
for (auto it = d.begin(); it != d.end(); ++it)
cout << *it << endl;
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果 −
Contents of deque before erase operation 1 2 3 4 5 Contents of deque after erase operation 2 3 4 5