当前位置: 首页 > news >正文

C++ 标准库 copy_if

在 C++ 中,有多种方法可以从一个容器拷贝符合条件的元素到另一个容器。以下是几种常用的方法:

1. 使用 std::copy_if 算法(推荐)

这是最简洁和现代的方法:

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::vector<int> source = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};std::vector<int> destination;// 拷贝所有偶数std::copy_if(source.begin(), source.end(), std::back_inserter(destination),[](int x) { return x % 2 == 0; });// 输出结果for (int num : destination) {std::cout << num << " ";}// 输出: 2 4 6 8 10return 0;
}

2. 使用 std::remove_copy_if(拷贝不满足条件的元素)

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::vector<int> source = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};std::vector<int> destination;// 拷贝所有不是偶数的元素(即奇数)std::remove_copy_if(source.begin(), source.end(),std::back_inserter(destination),[](int x) { return x % 2 == 0; });// 输出结果for (int num : destination) {std::cout << num << " ";}// 输出: 1 3 5 7 9return 0;
}

3. 对于关联容器(如 std::set, std::map)

#include <iostream>
#include <set>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::set<int> source = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};std::vector<int> destination;// 从 set 拷贝大于 5 的元素到 vectorstd::copy_if(source.begin(), source.end(),std::back_inserter(destination),[](int x) { return x > 5; });for (int num : destination) {std::cout << num << " ";}// 输出: 6 7 8 9 10return 0;
}

4. 性能考虑

如果知道大概有多少元素会被拷贝,可以预先分配空间:

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::vector<int> source = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};// 预先分配空间(可选,用于性能优化)std::vector<int> destination;destination.reserve(source.size()); // 最大可能的大小std::copy_if(source.begin(), source.end(),std::back_inserter(destination),[](int x) { return x % 2 == 0; });// 可以收缩空间以节省内存destination.shrink_to_fit();for (int num : destination) {std::cout << num << " ";}return 0;
}

总结

  • 推荐使用 std::copy_if:代码简洁,表达意图明确
  • 使用 std::back_inserter 作为输出迭代器,自动处理容器大小
  • 考虑性能:对于大型容器,可以预先分配空间
  • lambda 表达式:提供了灵活的条件判断方式

选择哪种方法取决于具体需求和个人偏好,但 std::copy_if 通常是首选,因为它提供了最好的可读性和简洁性。



note: from deepseek.
http://www.rkmt.cn/news/1616.html

相关文章:

  • 企查查API接口组合:解锁企业数据智能的实战密码
  • 微信公众号封面提取教程
  • 数据结构与算法-24.2-3查找树
  • IPv4向IPv6平滑过渡综合技术方案
  • TIA博图中的常用指令:定时器、计数器和触发器
  • Vue3项目开发专题精讲【左扬精讲】—— 企业网站系统(基于 Vue3 与 TypeScript 技术栈的企业网站系统开发实战)
  • win10使用openssl生成证书
  • linux服务器 系统服务文件
  • Critical Thinking Academic Writing
  • 1.3 课前问题思考
  • Visual Studio Code 开发环境搭建(Rust)
  • Spring Boot 项目中,同一个版本的依赖,内容却不一样?一次因依赖污染导致 Redis 启动失败的排查
  • 微信机器人开发文档
  • 大屏开发
  • [node] Linux 环境安装 nvm 并通过 nvm 控制 node 版本
  • Gitee崛起:中国开发者为何纷纷转向本土代码托管平台
  • Vue.js:大屏开发实战
  • xtrabackup8.0本地备份和恢复(xbstream+gzip)
  • Docker网络
  • 后端Coder如何做好代码设计?
  • 前端调试列出方法和属性
  • Linux /boot 目录详解
  • v-model的简单实现
  • 虚拟列表
  • 条码控件Aspose.BarCode教程:使用 C# 构建 Code11 条形码生成器
  • 物理焦距、像素焦距、像元与相机内参(fx, fy)的意义与作用
  • java课前问题列表
  • vue3中两对容易搞混的概念
  • LoadRunner 对 WebTours 实现订票的性能分析
  • Python游戏开发:使用Pygame库的全面教程