gpt4 book ai didi

c++ - 使用 ppl.h 查找最大值

转载 作者:塔克拉玛干 更新时间:2023-11-03 06:45:03 26 4
gpt4 key购买 nike

C++ 的 ppl 库中是否有一个简单的函数,您可以在其中执行类似 Concurrency::max(vec) 的操作,其中 vec 是数字 vector ?我可以自己写,但我希望我可以省去自己的工作。

编辑:对不起,我可能不够清楚。我需要 max 函数来利用并行化。

最佳答案

没有内置任何内容,但使用可组合(归约变量)和并行循环(此处为 parallel_for_each)很简单。但是,如果您正在做的工作只是数字的“最大”,除非您正在查看的数字数量非常大,否则可能很难看到加速。

您可以在 msdn 上阅读更多相关信息:

#include <ppl.h>
#include <climits>
#include <vector>
#include <numeric>
#include <iostream>
using namespace Concurrency;
int main(int argc, _TCHAR* argv[])
{
std::vector<int> vec(10);
std::iota( begin(vec), end(vec), 1);
combinable<int> locals([]{ return INT_MIN; });
parallel_for_each( begin(vec), end(vec), [&locals](int cur){
auto & localMax = locals.local();
localMax = std::max(cur, localMax);
});
std::cout << "max is " << locals.combine([](int left, int right){ return std::max<int>(left, right);}) << std::endl;
return 0;
}

关于c++ - 使用 ppl.h 查找最大值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22939121/

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