////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2017-2017. // Distributed under the Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // See http://www.boost.org/libs/move for documentation. // ////////////////////////////////////////////////////////////////////////////// #ifndef BOOST_MOVE_ALGO_UNIQUE_HPP #define BOOST_MOVE_ALGO_UNIQUE_HPP #include #include namespace boost { namespace movelib { //! Requires: The comparison function shall be an equivalence relation. The type of *first shall satisfy //! the MoveAssignable requirements //! //! Effects: For a nonempty range, eliminates all but the first element from every consecutive group //! of equivalent elements referred to by the iterator i in the range [first + 1, last) for which the //! following conditions hold: pred(*(i - 1), *i) != false. //! //! Returns: The end of the resulting range. //! //! Complexity: For nonempty ranges, exactly (last - first) - 1 applications of the corresponding predicate. template ForwardIterator unique(ForwardIterator first, ForwardIterator last, BinaryPredicate pred) { if (first != last) { ForwardIterator next(first); ++next; for (; next != last; ++next, ++first) { if (pred(*first, *next)) { //Find first equal element while (++next != last) if (!pred(*first, *next)) *++first = ::boost::move(*next); break; } } ++first; } return first; } } //namespace movelib { } //namespace boost { #include #endif //#define BOOST_MOVE_ALGO_UNIQUE_HPP