std::unique仅去除相邻重复元素,需配合sort和erase实现全去重。先排序使相同值相邻,再用std::unique移动重复元素,最后调用erase删除尾部冗余。若需保持原序,可用unordered_set记录已见元素,结合remove_if移除后续重复项。注意std::unique不改变容器大小,必须手动擦除;未排序数据直接使用unique无法彻底去重。典型做法为排序+unique+erase或哈希集合+remove_if+erase。

在C++中,std::unique 并不能直接移除 vector 中所有重复的元素,它只能去除相邻的重复元素。因此,要真正实现去重,需要结合 std::sort 和 erase 方法。
std::unique 会遍历区间,将连续相同的元素“压缩”,只保留第一个,返回一个指向新逻辑结尾的迭代器。但它不会改变容器大小。
例如:
vector
auto it = std::unique(v.begin(), v.end());
// 此时 v 可能是 {1, 2, 3, 4, 3, 3, 4},后面是未定义内容
v.erase(it, v.end()); // 必须手动擦除多余部分
步骤如下:
立即学习“C++免费学习笔记(深入)”;
代码示例:
#include <vector>
#include <algorithm>
using namespace std;
vector
sort(nums.begin(), nums.end());
auto it = unique(nums.begin(), nums.end());
nums.erase(it, nums.end());
最终 nums 为:{1, 2, 3, 4, 5, 6, 9}
如果不想打乱原有顺序,就不能排序。这时可以用 set 或 unordered_set 辅助记录已出现的元素。
示例:
vector
unordered_set
auto it = remove_if(nums.begin(), nums.end(), [&seen](int x) {
if (seen.count(x)) return true;
seen.insert(x);
return false;
});
nums.erase(it, nums.end());
结果为:{3, 1, 4, 5, 9, 2, 6},保持第一次出现的顺序。
使用 std::unique 前必须排序,否则只能去掉连续重复项。
std::unique 不适用于未排序数据的全面去重。
erase-remove-if 模式是标准做法,配合哈希集合可高效去重并保留顺序。
基本上就这些,关键是理解 unique 只处理相邻重复,真正去重要配合 erase 使用。不复杂但容易忽略细节。
以上就是c++++如何使用std::unique移除vector中的重复元素_c++ unique去重操作方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号