unique.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. #ifndef _LIBCPP___ALGORITHM_UNIQUE_H
  9. #define _LIBCPP___ALGORITHM_UNIQUE_H
  10. #include <__algorithm/adjacent_find.h>
  11. #include <__algorithm/comp.h>
  12. #include <__config>
  13. #include <__iterator/iterator_traits.h>
  14. #include <__utility/move.h>
  15. #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
  16. # pragma GCC system_header
  17. #endif
  18. _LIBCPP_BEGIN_NAMESPACE_STD
  19. // unique
  20. template <class _ForwardIterator, class _BinaryPredicate>
  21. _LIBCPP_NODISCARD_EXT _LIBCPP_CONSTEXPR_AFTER_CXX17 _ForwardIterator
  22. unique(_ForwardIterator __first, _ForwardIterator __last, _BinaryPredicate __pred)
  23. {
  24. __first = _VSTD::adjacent_find<_ForwardIterator, _BinaryPredicate&>(__first, __last, __pred);
  25. if (__first != __last)
  26. {
  27. // ... a a ? ...
  28. // f i
  29. _ForwardIterator __i = __first;
  30. for (++__i; ++__i != __last;)
  31. if (!__pred(*__first, *__i))
  32. *++__first = _VSTD::move(*__i);
  33. ++__first;
  34. }
  35. return __first;
  36. }
  37. template <class _ForwardIterator>
  38. _LIBCPP_NODISCARD_EXT inline
  39. _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR_AFTER_CXX17
  40. _ForwardIterator
  41. unique(_ForwardIterator __first, _ForwardIterator __last)
  42. {
  43. typedef typename iterator_traits<_ForwardIterator>::value_type __v;
  44. return _VSTD::unique(__first, __last, __equal_to<__v>());
  45. }
  46. _LIBCPP_END_NAMESPACE_STD
  47. #endif // _LIBCPP___ALGORITHM_UNIQUE_H