C++ STL中可通过std::copy_if结合lambda谓词实现容器过滤,如过滤大于5的元素;也可手动遍历或使用std::remove_if与erase组合进行原地删除。

C++ STL本身并没有直接提供容器过滤功能,但我们可以利用算法库中的
std::copy_if
std::copy_if是一个非常强大的工具,它允许我们根据指定的谓词(predicate)来复制容器中的元素。谓词本质上就是一个返回bool值的函数或函数对象。
使用
std::copy_if
例如,假设我们有一个
std::vector<int>
立即学习“C++免费学习笔记(深入)”;
#include#include #include int main() { std::vector<int> numbers = {1, 6, 3, 8, 2, 9, 4, 7, 5}; std::vector<int> filtered_numbers; std::copy_if(numbers.begin(), numbers.end(), std::back_inserter(filtered_numbers), [](int n){ return n > 5; }); for (int num : filtered_numbers) { std::cout << num << " "; } std::cout << std::endl; // 输出:6 8 9 7 return 0; }
这里,我们使用了一个lambda表达式
[](int n){ return n > 5; }std::back_inserter
filtered_numbers
当然。可以手动遍历容器,然后根据条件将元素添加到新的容器中。虽然这种方法比较繁琐,但可以提供更大的灵活性,例如在过滤过程中进行一些额外的处理。
#include#include int main() { std::vector<int> numbers = {1, 6, 3, 8, 2, 9, 4, 7, 5}; std::vector<int> filtered_numbers; for (int num : numbers) { if (num > 5) { filtered_numbers.push_back(num); } } for (int num : filtered_numbers) { std::cout << num << " "; } std::cout << std::endl; // 输出:6 8 9 7 return 0; }
这种方法看起来更直接,但当过滤条件变得复杂时,
std::copy_if
功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类
0
过滤自定义类型的容器与过滤基本类型容器的方法类似,关键在于定义合适的谓词。谓词需要能够访问自定义类型的成员,并根据成员的值来判断是否满足过滤条件。
假设我们有一个
Person
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
class Person {
public:
std::string name;
int age;
Person(std::string n, int a) : name(n), age(a) {}
};
int main() {
std::vector<Person> people = {
{"Alice", 30},
{"Bob", 25},
{"Charlie", 35},
{"David", 20}
};
std::vector<Person> filtered_people;
std::copy_if(people.begin(), people.end(), std::back_inserter(filtered_people), [](const Person& p){ return p.age > 25; });
for (const Person& person : filtered_people) {
std::cout << person.name << " (" << person.age << ") ";
}
std::cout << std::endl; // 输出:Alice (30) Charlie (35)
return 0;
}在这个例子中,lambda表达式
[](const Person& p){ return p.age > 25; }Person
age
age
const Person&
在大多数情况下,
std::copy_if
std::copy_if
总的来说,
std::copy_if
std::copy_if
如果你想直接修改原始容器,移除不满足条件的元素,可以使用
std::remove_if
erase
std::remove_if
erase
#include#include #include int main() { std::vector<int> numbers = {1, 6, 3, 8, 2, 9, 4, 7, 5}; numbers.erase(std::remove_if(numbers.begin(), numbers.end(), [](int n){ return n <= 5; }), numbers.end()); for (int num : numbers) { std::cout << num << " "; } std::cout << std::endl; // 输出:6 8 9 7 return 0; }
需要注意的是,
std::remove_if
erase
以上就是C++如何在STL中实现容器过滤功能的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号