使用场景
消除重复单词,假设有以下单词
over | jumps | red | slow | the | fox | quick | turtle | the | red |
思路
- 将单词放入vector
- 对vector进行排序,使得重复的单词相邻出现
- 使用标准库的unique算法重排vector,使得不重复的元素出现在vector开始部分
- 由于算法不能执行容器操作,使用erase成员完成真正的删除操作
代码
void elimDups(vector<string> &words) {
// 按字典序排序
sort(words.begin(), words.end());
// unique重排输入范围
// 排列在范围的前部,返回指向不重复区域之后一个位置的迭代器
auto end_unique = unique(words.begin(), words.end());
// 删除重复单词
words.erase(end_unique, words.end());
}
使用unique
调用unique后,vector将变为:
fox | jumps | over | quick | red | slow | the | turtle | ??? | ??? |
返回的end_unique迭代器指向第一个???
words的大小并未改变,它仍有10个元素。unique返回的迭代器指向最后一个不重复元素之后的位置。此位置之后的元素仍然存在,但我们不知道它们的值是什么。