C++ Deque::end() 函数



C++ 的std::deque::end()函数用于返回一个指向deque中最后一个元素之后位置的迭代器。这个元素充当占位符,不包含任何有效值。end()函数用于定义一个范围,该范围包含deque中的所有元素,除了最后一个元素。

语法

以下是std::deque::end()函数的语法。

iterator end() noexcept;
const_iterator end() const noexcept;

参数

它不接受任何参数。

返回值

它返回一个指向最后一个元素之后位置的迭代器。

异常

此函数从不抛出异常。

时间复杂度

此函数的时间复杂度为常数,即O(1)。

示例

让我们看下面的例子,我们将使用insert()和end()在deque的末尾插入元素。

#include <iostream>
#include <deque>
int main()
{
    std::deque<char> x = {'A', 'B', 'C', 'D'};
    x.insert(x.end(), 'E');
    for (std::deque<char>::iterator a = x.begin(); a != x.end(); ++a) {
        std::cout << *a << " ";
    }
    std::cout << std::endl;
    return 0;
}

输出

以上代码的输出如下:

A B C D E

示例

考虑下面的例子,我们将把另一个容器中的一系列元素附加到deque的末尾。

#include <iostream>
#include <deque>
#include <vector>
int main()
{
    std::deque<char> a = {'A', 'B', 'C'};
    std::vector<char> b = {'X', 'Y', 'Z'};
    a.insert(a.end(), b.begin(), b.end());
    for (std::deque<char>::iterator x = a.begin(); x != a.end(); ++x) {
        std::cout << *x << " ";
    }
    std::cout << std::endl;
    return 0;
}

输出

以上代码的输出如下:

A B C X Y Z

示例

在下面的例子中,我们将使用erase()和end()删除deque的最后一个元素。

#include <iostream>
#include <deque>
int main()
{
    std::deque<int> x = {1, 22, 333, 4444};
    x.erase(x.end() - 1);
    for (std::deque<int>::iterator a = x.begin(); a != x.end(); ++a) {
        std::cout << *a << " ";
    }
    std::cout << std::endl;
    return 0;
}

输出

如果我们运行以上代码,它将生成以下输出:

1 22 333
deque.htm
广告