std::list<T,Allocator>:: unique
| (1) | ||
|
void
unique
(
)
;
|
(C++20まで) | |
|
size_type unique
(
)
;
|
(C++20から)
(constexpr C++26から) |
|
| (2) | ||
|
template
<
class
BinaryPred
>
void unique ( BinaryPred p ) ; |
(C++20まで) | |
|
template
<
class
BinaryPred
>
size_type unique ( BinaryPred p ) ; |
(C++20から)
(constexpr C++26から) |
|
コンテナからすべての 連続した 重複要素を削除します。各等価要素グループの最初の要素のみが残されます。
削除された要素に対するイテレータと参照のみを無効化します。
目次 |
パラメータ
| p | - |
要素が等しいと扱われるべき場合に
true
を返す二項述語。
述語関数のシグネチャは以下と同等であるべきです: bool pred ( const Type1 & a, const Type2 & b ) ;
シグネチャが
const
&
を持つ必要はありませんが、関数は渡されたオブジェクトを変更してはならず、
値カテゴリ
に関係なく型(おそらくconstの)
|
| 型要件 | ||
-
BinaryPred
は
BinaryPredicate
の要件を満たさなければなりません。
|
||
戻り値
|
(なし) |
(C++20まで) |
|
削除された要素の数。 |
(C++20以降) |
計算量
empty() が true の場合、比較は実行されません。
それ以外の場合、 N を std:: distance ( begin ( ) , end ( ) ) として定義する:
注記
| 機能テスト マクロ | 値 | 標準 | 機能 |
|---|---|---|---|
__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 |
イテレータおよび/または参照が無効化されるかどうかが不明確
であった |
削除された要素へのイテレータと参照のみを
無効化する |
関連項目
|
連続する重複要素を範囲から削除する
(関数テンプレート) |