首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用ppl.h查找最大值

用ppl.h查找最大值
EN

Stack Overflow用户
提问于 2014-04-08 13:50:42
回答 2查看 488关注 0票数 2

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

编辑:对不起,也许我说得不够清楚。我需要最大的函数来利用并行化。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-08 16:58:34

没有内置的任何内容,但是通过组合(一个约简变量)和一个并行循环(这里是parallel_for_each),它是很简单的。但是,如果你正在做的工作只是数字的“最大值”,除非你看到的数字数量非常大,那么你可能很难看到加速。

你可以在msdn上读到更多关于它的信息。

代码语言:javascript
复制
#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;
}
票数 2
EN

Stack Overflow用户

发布于 2014-04-08 13:56:07

它只是一个std::vector吗?如果是这样,您可以使用max_element

代码语言:javascript
复制
auto it = std::max_element(std::begin(vec), std::end(vec));

迭代器it然后指向具有最大值的向量元素。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22939121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档