gpt4 book ai didi

c++ - 使用标准算法从容器中移除对象

转载 作者:行者123 更新时间:2023-11-30 01:42:47 25 4
gpt4 key购买 nike

假设我有一个 std::unordered_set 存储类 A 的对象。现在我想删除满足给定 condition 的对象子集,并将另一个函数应用于子集中的每个对象。执行此操作的最佳(或优雅)方法是什么?

一个可能的解决方案是:

std::unordered_set<A> myset;

//.. initialize data

std::for_each(myset.begin(), myset.end(), [](A&) { if(condition(A)) { /*do something on A*/} });

auto itrs = std::remove_if(myset.begin(), myset.end(), [](A&) {return condition(A)});
myset.erase(itrs, myset.end());

显然上述解决方案需要两步函数调用。有什么办法可以简化这个吗?

最佳答案

首先编写一个算法,根据关联容器中的谓词进行删除(删除/删除 - 如果对 unordered_set 不起作用):

template <class Container, class Predicate>
void erase_if(Container& c, Predicate pred)
{
using std::begin;
using std::end;

auto first = begin(c);
auto last = end(c);
while (first != last) {
if (pred(*first)) {
first = c.erase(first);
}
else {
++first;
}
}
}

然后只需传入一个谓词来检查您的条件,然后执行一些操作:

erase_if(myset, [](A const& a) {
if (condition(a)) {
/* do something */
return true;
}
return false;
});

关于c++ - 使用标准算法从容器中移除对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38925182/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com