首页 > 后端开发 > C++ > 正文

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

Linda Hamilton
发布: 2024-11-13 05:59:02
原创
380 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板