zoukankan      html  css  js  c++  java
  • vector去重--unique

    具体实现见中间源码
    function template
    <algorithm>

    std::unique

    equality (1)
    template <class ForwardIterator>
      ForwardIterator unique (ForwardIterator first, ForwardIterator last);
    
    predicate (2)
    template <class ForwardIterator, class BinaryPredicate>
      ForwardIterator unique (ForwardIterator first, ForwardIterator last,
                              BinaryPredicate pred);
    Remove consecutive duplicates in range
    Removes all but the first element from every consecutive group of equivalent elements in the range [first,last).

    The function cannot alter the properties of the object containing the range of elements (i.e., it cannot alter the size of an array or a container): The removal is done by replacing the duplicate elements by the next element that is not a duplicate, and signaling the new size of the shortened range by returning an iterator to the element that should be considered its new past-the-end element.

    The relative order of the elements not removed is preserved, while the elements between the returned iterator and lastare left in a valid but unspecified state.

    The function uses operator== to compare the pairs of elements (or pred, in version (2)).

    The behavior of this function template is equivalent to:
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    
    template <class ForwardIterator>
      ForwardIterator unique (ForwardIterator first, ForwardIterator last)
    {
      if (first==last) return last;
    
      ForwardIterator result = first;
      while (++first != last)
      {
        if (!(*result == *first))  // or: if (!pred(*result,*first)) for version (2)
          *(++result)=*first;
      }
      return ++result;
    }
     


    Parameters

    first, last
    Forward iterators to the initial and final positions of the sequence of move-assignable elements. The range used is[first,last), which contains all the elements between first and last, including the element pointed by first but not the element pointed by last.
    pred
    Binary function that accepts two elements in the range as argument, and returns a value convertible to bool. The value returned indicates whether both arguments are considered equivalent (if true, they are equivalent and one of them is removed).
    The function shall not modify any of its arguments.
    This can either be a function pointer or a function object.

    Return value

    An iterator to the element that follows the last element not removed.
    The range between first and this iterator includes all the elements in the sequence that were not considered duplicates.

    Example

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    
    // unique algorithm example
    #include <iostream>     // std::cout
    #include <algorithm>    // std::unique, std::distance
    #include <vector>       // std::vector
    
    bool myfunction (int i, int j) {
      return (i==j);
    }
    
    int main () {
      int myints[] = {10,20,20,20,30,30,20,20,10};           // 10 20 20 20 30 30 20 20 10
      std::vector<int> myvector (myints,myints+9);
    
      // using default comparison:
      std::vector<int>::iterator it;
      it = std::unique (myvector.begin(), myvector.end());   // 10 20 30 20 10 ?  ?  ?  ?
                                                             //                ^
    
      myvector.resize( std::distance(myvector.begin(),it) ); // 10 20 30 20 10
    
      // using predicate comparison:
      std::unique (myvector.begin(), myvector.end(), myfunction);   // (no changes)
    
      // print out content:
      std::cout << "myvector contains:";
      for (it=myvector.begin(); it!=myvector.end(); ++it)
        std::cout << ' ' << *it;
      std::cout << '
    ';
    
      return 0;
    }


    Output:
    myvector contains: 10 20 30 20 10
    

    Complexity

    For non-empty ranges, linear in one less than the distance between first and last: Compares each pair of consecutive elements, and possibly performs assignments on some of them.

    Data races

    The objects in the range [first,last) are accessed and potentially modified.

    Exceptions

    Throws if any of pred, the element comparisons, the element assignments or the operations on iterators throws.

    Note that invalid arguments cause undefined behavior.

    另一个实例:

    #include <iostream>
    #include <vector>
    #include <algorithm>
    #include <iterator>
    /* 删除容器内重复元素,分三步处理
    * 1、先排序容器元素
    * 2、取得重复元素首部迭代器
    * 3、删除重复元素
    */
    using namespace std;

    int main()
    {
        int a[]={1,2,3,1,2,4,4,5};
        const int len = sizeof(a)/sizeof(int);
        vector<int> va(len);// 定义一个与数组等长的容器
        copy(a, a + len, va.begin());
        ostream_iterator<int, char> oi(cout," ");//定义一个输出流迭代器
        copy(va.begin(), va.end(), oi);
        cout << " 容器内元素顺序输出结果" << endl;
        // sort(两个参数)默认升序排列元素,如果不是基本类型,请重载操作符opearte<.
        // sort (三个参数) sort(va.begin(),va.end(),handle_v);
        // 自己写函数实现处理两个元素参数 bool handle_v(const int & a,cont int & b){};
        sort(va.begin(), va.end());
        vector<int>::iterator it = unique(va.begin(),va.end());
        va.erase(it, va.end());
        copy(va.begin(), va.end(), oi);
        cout << " 删除重复元素后顺序输出结果" << endl;
        return 0;
    }


  • 相关阅读:
    shape与reshape
    opencv4.5.0 +contrib编译流程
    人脸定位(haar特征)
    最近邻分类法
    人脸识别概述
    跟踪视频中的物体
    估算稠密光流
    resize函数
    swap函数
    hibernate的session执行增删改查方法的执行步骤
  • 原文地址:https://www.cnblogs.com/freeopen/p/5483002.html
Copyright © 2011-2022 走看看