0

0

c++中如何使用std::unique_copy_c++去除连续重复元素方法【详解】

穿越時空

穿越時空

发布时间:2026-01-20 13:23:31

|

996人浏览过

|

来源于php中文网

原创

std::unique_copy 是 中的合法函数,用于将输入范围中连续重复的元素去重后复制到目标容器,不修改原容器,仅跳过相邻相等元素,要求源支持前向迭代器、目标空间充足或使用插入迭代器,且元素支持 operator== 或自定义谓词。

c++中如何使用std::unique_copy_c++去除连续重复元素方法【详解】

标准库中没有 std::unique_copy_c++ 这个函数,它并不存在 —— 你很可能把 std::unique_copy 和语言名拼错了,或者误记成了某个自定义封装名。

std::unique_copy 的基本用法和必要前提

std::unique_copy 中的合法函数,作用是:将输入范围中「连续重复」的元素去重后复制到目标容器,**不修改原容器**。但它只跳过相邻相等元素,不是全局去重。

  • 源范围必须支持前向迭代器(如 std::vectorstd::listbegin()/end()
  • 目标容器需有足够空间,或使用插入迭代器(如 std::back_inserter
  • 元素需支持 operator==,或传入自定义二元谓词
std::vector src = {1, 1, 2, 2, 2, 3, 4, 4, 5};
std::vector dst;
std::unique_copy(src.begin(), src.end(), std::back_inserter(dst));
// dst == {1, 2, 3, 4, 5}

为什么 std::unique_copy 不处理非连续重复

它内部逻辑仅比较当前元素与前一个已复制元素(或前一位置),不做任何查找或哈希。例如:{1, 2, 1}std::unique_copy 后仍是 {1, 2, 1},因为两个 1 不连续。

  • 这是设计使然:保持 O(n) 时间复杂度和单次遍历特性
  • 若需全局去重且保持顺序,应先用 std::unordered_set 记录已见元素,再手动过滤
  • 若允许重排,可先 std::sort 再用 std::unique_copy,但会丢失原始顺序

常见错误:忘记排序就期望去重所有重复项

典型误用:

立即学习C++免费学习笔记(深入)”;

Lumen5
Lumen5

一个在线视频创建平台,AI将博客文章转换成视频

下载
std::vector v = {3, 1, 3, 2, 1};
std::vector out;
std::unique_copy(v.begin(), v.end(), std::back_inserter(out)); // 错!out == {3,1,3,2,1}

正确做法取决于需求:

  • 保持顺序 + 全局去重 → 手写循环 + std::unordered_set
  • 不关心顺序 → std::sort + std::unique_copy
  • 原地操作(非复制)→ 用 std::unique + erase

与 std::unique 的关键区别

std::unique 作用于原容器,返回新逻辑终点迭代器,需配合 erase 才真正缩容;而 std::unique_copy 是纯函数式,不改变输入,只写目标。

  • std::unique(v.begin(), v.end()) 返回指向新尾部的迭代器,但 v.size() 不变
  • std::unique_copy 要求目标空间足够,否则行为未定义(比如用普通指针目标但空间不足)
  • 两者都只处理连续重复,这点完全一致

真正容易被忽略的是:哪怕你传了正确的函数名和头文件,如果源数据没按需预处理(比如该排序却没排),结果就不是你想要的“去重”。别让名字里的 unique 暗示误导你对语义的判断。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

52

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

54

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

35

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

9

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

15

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

125

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

138

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号