命名空间
变体
操作

std::list<T,Allocator>::unique

来自 cppreference.cn
< cpp‎ | container‎ | list
 
 
 
 
(1)
void unique();
(直到 C++20)
size_type unique();
(自 C++20 起)
(2)
template< class BinaryPredicate >
void unique( BinaryPredicate p );
(直到 C++20)
template< class BinaryPredicate >
size_type unique( BinaryPredicate p );
(自 C++20 起)

从容器中移除所有连续的重复元素。只留下每组相等元素中的第一个元素。仅使指向已移除元素的迭代器和引用失效。

1) 使用 operator== 来比较元素。
2) 使用 p 来比较元素。

如果对应的比较器未建立等价关系,则行为未定义。

目录

[编辑] 参数

p - 二元谓词,如果元素应被视为相等,则返回 ​true

谓词函数的签名应等效于以下内容

 bool pred(const Type1 &a, const Type2 &b);

虽然签名不需要具有 const &,但该函数不得修改传递给它的对象,并且必须能够接受类型为 (可能是 const) Type1Type2 的所有值,而与值类别无关 (因此,不允许使用 Type1 &,除非对于 Type1,移动等同于复制,否则也不允许使用 Type1(自 C++11 起))。
类型 Type1Type2 必须是这样的类型:类型为 list<T,Allocator>::const_iterator 的对象可以被解引用,然后隐式转换为它们两者。 ​

类型要求
-
BinaryPredicate 必须满足 BinaryPredicate 的要求。

[编辑] 返回值

(无)

(直到 C++20)

移除的元素数量。

(自 C++20 起)

[编辑] 复杂度

如果 empty()true,则不执行比较。

否则,给定 N 作为 std::distance(begin(), end())

1) 使用 operator== 精确进行 N-1 次比较。
2) 精确应用谓词 p N-1 次。

[编辑] 注解

特性测试 Std 特性
__cpp_lib_list_remove_return_type 201806L (C++20) 更改返回类型

[编辑] 示例

#include <iostream>
#include <list>
 
std::ostream& operator<< (std::ostream& os, std::list<int> const& container)
{
    for (int val : container)
        os << val << ' ';
    return os << '\n';
}
 
int main()
{
    std::list<int> c{1, 2, 2, 3, 3, 2, 1, 1, 2};
    std::cout << "Before unique(): " << c;
    const auto count1 = c.unique();
    std::cout << "After unique():  " << c
              << count1 << " elements were removed\n";
 
    c = {1, 2, 12, 23, 3, 2, 51, 1, 2, 2};
    std::cout << "\nBefore unique(pred): " << c;
 
    const auto count2 = c.unique([mod = 10](int x, int y)
    {
        return (x % mod) == (y % mod);
    });
 
    std::cout << "After unique(pred):  " << c
              << count2 << " elements were removed\n";
}

输出

Before unique(): 1 2 2 3 3 2 1 1 2
After unique():  1 2 3 2 1 2
3 elements were removed
 
Before unique(pred): 1 2 12 23 3 2 51 1 2 2
After unique(pred):  1 2 23 2 51 2
4 elements were removed

缺陷报告

以下行为更改缺陷报告已追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 1207 C++98 不清楚迭代器
和/或引用是否会失效
仅使迭代器和
对已移除元素的引用失效

[编辑] 参见

移除范围内的连续重复元素
(函数模板) [编辑]