gpt4 book ai didi

c++ - 在容器中查找高于阈值的最大和最小元素

转载 作者:太空狗 更新时间:2023-10-29 21:15:28 24 4
gpt4 key购买 nike

我有一个看起来像这样的容器:std::map<size_t, std::set<char>>

我想找到阈值以上的绝对最大元素和最小元素 x基于 std::set 的大小.

我可以使用以下行获取最大值和最小值:

auto minMaxElements = std::minmax_element(cbegin(map), cend(map), 
[](const auto &lhs, const auto &rhs){
return lhs.second.size() < rhs.second.size();
});

是否有可能使最小元素超过阈值 x使用 std::minmax_element?

例子:假设我有一个 std::map5元素。 std::set 的大小值为 1, 2, 1, 10, and 5 .我将阈值设置为 1 ,然后我希望 max 元素给出包含 std::set 的迭代器尺寸10和 min 元素给出包含 std::set 的迭代器尺寸2 .

最佳答案

你可以使用 std::find_if 来做到这一点

auto it = std::find_if(map.begin(), map.end(), 
[x](const auto & l) -> bool {
return l.second.size() >= x; // >= or >, depending upon requirement
}
);

然后在您的 std::minmax_element 中使用此迭代器

auto minMaxElements = std::minmax_element(it, map.end(), 
[](const auto & lhs, const auto & rhs) {
return lhs.second.size() < rhs.second.size();
}
);

关于c++ - 在容器中查找高于阈值的最大和最小元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37693748/

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