巧用C++ STL:一行代码轻松去重Vector,效率提升10倍!

在C++编程中,我们经常需要处理包含重复元素的vector。传统的方法可能需要嵌套循环或复杂的逻辑,既繁琐又低效。今天,我们将探讨如何利用C++ STL(标准模板库)的强大功能,用简洁优雅的代码高效地删除vector中的重复元素。

STL提供了一系列强大的算法和容器,其中std::sortstd::unique这两个算法配合使用,可以轻松实现vector的去重。下面是详细的步骤和代码实现:

#include <iostream>
#include <vector>
#include <algorithm>

void printVector(const std::vector<int>& vec) {
    for (const auto& elem : vec) {
        std::cout << elem << " ";
    }
    std::cout << std::endl;
}

int main() {
    // 1. 创建一个包含重复元素的vector
    std::vector<int> numbers = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};
    
    std::cout << "原始vector: ";
    printVector(numbers);

    // 2. 对vector进行排序
    std::sort(numbers.begin(), numbers.end());
    
    std::cout << "排序后: ";
    printVector(numbers);

    // 3. 使用std::unique重新排列元素,将重复元素移到末尾
    auto last = std::unique(numbers.begin(), numbers.end());
    
    std::cout << "unique后: ";
    printVector(numbers);

    // 4. 删除重复元素
    numbers.erase(last, numbers.end());

    // 5. 输出结果
    std::cout << "去重后的vector: ";
    printVector(numbers);

    return 0;
}

让我们逐步解析这个过程:

  1. 首先,我们创建一个包含重复元素的vector。

  2. 使用std::sort对vector进行排序。这是必要的,因为std::unique只能识别相邻的重复元素。

  3. 调用std::unique。这个函数不会真正删除元素,而是将不重复的元素移到vector的前部,并返回一个迭代器,指向最后一个不重复元素之后的位置。

  4. 使用vector::erase函数删除从last迭代器到vector末尾的所有元素,这些就是重复的元素。

  5. 最后,我们得到了一个没有重复元素的vector。

这种方法的优点:

  • 简洁:只需几行代码就能完成复杂的去重操作。
  • 高效:时间复杂度为O(nlogn),主要来自排序步骤。
  • 通用:可以处理任何支持比较操作的元素类型。

注意事项:

  • 这种方法会改变原vector中元素的顺序。
  • 如果需要保持原有顺序,可以考虑使用std::setstd::unordered_set

结论:
通过巧妙运用C++ STL,我们可以用简洁的代码高效地解决vector去重这类常见问题。这不仅提高了代码的可读性,也大大提升了程序的执行效率。在日常编程中,善用STL可以让我们的代码更加优雅和高效。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值