• STL 中元素删除相关算法


    remove

    ①.头文件

    remove 算法定义在头文件 #include 中。

    ②.算法作用

    remove 算法不会改变序列的大小,是通过后面元素往前覆盖实现的,返回新序列有效值的下一个迭代器。

    ③.代码示例

    vector<int> vec = { 1,2,3,6,3,7,3,8,9 };
    cout << "原序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i<< " "; });
        
    auto iter = remove(vec.begin(), vec.end(), 3);
        
    cout << endl <<  "remove 后:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
        
    vec.erase(iter, vec.end());
    cout << endl << "新序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    在这里插入图片描述

    remove_if

    ①.头文件

    remove_if 算法定义在头文件 #include 中。

    ②.算法作用

    remove_if 算法是 remove 的升级版本,可以通过指定一个一元谓词来决定是否移除一个元素,执行结果同 remove 。

    ③.代码示例

    vector<int> vec = { 1,2,3,6,3,7,3,8,9 };
    cout << "原序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i<< " "; });
        
    vec.erase(remove_if(vec.begin(), vec.end(), [](int i) { return i < 4; }), vec.end());
    cout << endl << "新序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    remove_copy

    ①.头文件

    remove_copy 算法定义在头文件 #include 中。

    ②.算法作用

    remove_copy 算法执行结果是把删除指定元素后的剩余元素拷贝到一个新的序列 。

    ③.代码示例

    vector<int> vec = { 1,2,3,6,3,7,3,8,9 };
    cout << "原序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i<< " "; });
        
    vector<int> vec2;
    remove_copy(vec.begin(), vec.end(), back_inserter(vec2), 3);
       
    cout << endl << "新序列:" << endl;
    for_each(vec2.begin(), vec2.end(), [](int i) {cout << i << " "; });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    在这里插入图片描述

    unique

    ①.头文件

    unique 算法定义在头文件 #include 中。

    ②.算法作用

    unique 算法作用是移除序列中相邻的重复元素,不会改变序列的大小,是通过后面元素往前覆盖实现的,返回新序列有效值的下一个迭代器。

    ③.代码示例

    vector<int> vec = { 1,2,3,3,3,3,3,8,9 };
    cout << "原序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
    
    auto iter = unique(vec.begin(), vec.end());
    
    cout << endl << "remove 后:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
    
    vec.erase(iter, vec.end());
    cout << endl << "新序列:" << endl;
    for_each(vec.begin(), vec.end(), [](int i) {cout << i << " "; });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    在这里插入图片描述

    在这里插入图片描述

  • 相关阅读:
    【机器学习笔记】【随机森林】【分类器】
    go 1.18新特性(泛性 模糊测试 WorkSpace)
    项目管理工具禅道
    简易的聊天界面以及聊天机器人的实现
    GitHub 的 9 种加速方式
    多态(个人学习笔记黑马学习)
    盲水印接口,版权保护,防止篡改
    剑指 Offer 10- I. 斐波那契数列
    【GD32F427开发板试用】+rtt-thread nano+finsh极简开发
    Docker 数据管理和网络通信
  • 原文地址:https://blog.csdn.net/lizhichao410/article/details/125617402