C++ STL删除之------remove_copy和remove_copy_if

260 篇文章 9 订阅

remove_copy
移除[first,last)之中所有与value相等的元素。然而并不是真正的从容器中删除那些元素,而是将结果复制到一个以result标示起始位置的容器身上。


remove_copy_if
移除[first,last)区间内所有仿函数pred核定为true的元素。它并不是真正从容器中删除那些元素,而是将结果复制到一个以result标示起始位置的容器身上。新容器可以和原容器重叠,但如果针对新容器实际给值时,超越了新容器的大小,会发生无法预期的结果。
 

///remove_copy///
    {
        int ia[] = { 0,1,2,3,4,5,6,6,6,7,8 };
        vector<int> iv(begin(ia), end(ia));
        //移除(但不删除)元素6,结果置于另一个区间
        vector<int> iv2(12);
        remove_copy(iv.begin(), iv.end(), iv2.begin(), 6);
        for_each(iv2.begin(), iv2.end(), display<int>); cout << endl;
        //0 1 2 3 4 5 7 8 (0 0 0 0)
    }
   
    ///remove_copy_if///
    {
        int ia[] = { 0,1,2,3,4,5,6,6,6,7,8 };
        vector<int> iv(begin(ia), end(ia));

        //移除(但不删除)小于7的元素,结果置于另一个区间
        vector<int> iv2(12);
        remove_copy_if(iv.begin(), iv.end(), iv2.begin(), bind2nd(less<int>(), 7));
        for_each(iv2.begin(), iv2.end(), display<int>); cout << endl;
        //7 8 0 0 0 0 0 0 0 0 0 0
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这三个函数STL 算法用于删除元素的函数。它们的作用分别是: - `remove_if`:删除满足指定条件的元素,返回指向新的逻辑结尾的迭代器。 - `remove_copy`:将满足指定条件的元素拷贝到另一个容器,返回指向新的逻辑结尾的迭代器。 - `remove_copy_if`:将不满足指定条件的元素拷贝到另一个容器,返回指向新的逻辑结尾的迭代器。 下面是它们的用法和示例: ```cpp #include <iostream> #include <algorithm> #include <vector> using namespace std; int main() { // remove_if vector<int> v1{1, 2, 3, 4, 5}; auto it1 = remove_if(v1.begin(), v1.end(), [](int x) { return x % 2 == 0; }); v1.erase(it1, v1.end()); for (int x : v1) { cout << x << " "; // 输出 1 3 5 } cout << endl; // remove_copy vector<int> v2{1, 2, 3, 4, 5}; vector<int> v3; remove_copy(v2.begin(), v2.end(), back_inserter(v3), [](int x) { return x % 2 == 0; }); for (int x : v3) { cout << x << " "; // 输出 1 3 5 } cout << endl; // remove_copy_if vector<int> v4{1, 2, 3, 4, 5}; vector<int> v5; remove_copy_if(v4.begin(), v4.end(), back_inserter(v5), [](int x) { return x % 2 == 0; }); for (int x : v5) { cout << x << " "; // 输出 1 3 5 } cout << endl; return 0; } ``` 注意,这三个函数并不真正删除容器的元素,而是返回指向新的逻辑结尾的迭代器。如果要真正删除元素,需要结合容器的 `erase` 函数使用。此外,`remove_copy` 和 `remove_copy_if` 会将满足条件的元素拷贝到另一个容器,因此要注意目标容器的类型和大小。在示例,使用了 `back_inserter` 函数将元素插入 `vector` 的尾部。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值