首页  >  文章  >  后端开发  >  如何在保持顺序的同时从未排序的向量中删除重复项?

如何在保持顺序的同时从未排序的向量中删除重复项?

Linda Hamilton
Linda Hamilton原创
2024-11-13 05:59:02381浏览

How to Remove Duplicates from an Unsorted Vector while Maintaining Order?

从未排序的向量中删除重复项

在各种情况下,保持首次出现的顺序,同时从未排序的向量中消除重复项至关重要。虽然利用集合和手动迭代的直接方法是有效的,但可以通过利用 STL 算法对其进行改进。

为了实现这一点,std::copy_if 算法提供了一种方便的解决方案。通过定义一个谓词来跟踪已处理的元素并为重复项返回 false,我们可以过滤掉所需的元素。

如果 C 11 支持不可用,则可以使用笨拙的名为 std::remove_copy_if 的方法,它的逻辑颠倒了。下面是一个未经测试的示例来说明:

template <typename T>
struct NotDuplicate {
  bool operator()(const T& element) {
    return s_.insert(element).second; // true if s_.insert(element);
  }
 private:
  std::set<T> s_;
};

接下来,可以使用以下代码:

std::vector<int> uniqueNumbers;
NotDuplicate<int> pred;
std::copy_if(numbers.begin(), numbers.end(), 
             std::back_inserter(uniqueNumbers),
             std::ref(pred));

在此解决方案中,std::ref 确保有状态函子不是在算法内部复制。然而,std::copy_if 并不对所应用函子的副作用施加任何要求。

以上是如何在保持顺序的同时从未排序的向量中删除重复项?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn