当前位置: 首页 > wzjs >正文

佛山市禅城网站建设杭州网站建设制作公司

佛山市禅城网站建设,杭州网站建设制作公司,建e网全景合成,wap开头的网址文章目录 1. 简介2. 函数签名3. 使用场景3.1 简单的累加操作3.2 自定义归并操作3.3 并行计算的性能优势 4. 注意事项4.1 归并操作的结合律和交换律4.2 默认值的使用 5. 总结 1. 简介 std::reduce 是 C17 标准库中引入的一个算法,用于对范围内的元素进行归并操作。它…

根据比例生成图片 (4).png

文章目录

    • 1. 简介
    • 2. 函数签名
    • 3. 使用场景
      • 3.1 简单的累加操作
      • 3.2 自定义归并操作
      • 3.3 并行计算的性能优势
    • 4. 注意事项
      • 4.1 归并操作的结合律和交换律
      • 4.2 默认值的使用
    • 5. 总结

1. 简介

std::reduce 是 C++17 标准库中引入的一个算法,用于对范围内的元素进行归并操作。它类似于 std::accumulate,但在某些情况下提供了更灵活的处理方式,尤其是在并行计算方面。

2. 函数签名

std::reduce 的基本函数签名如下:

template<class InputIt>
typename std::iterator_traits<InputIt>::value_type
reduce(InputIt first, InputIt last);template<class InputIt, class T>
T reduce(InputIt first, InputIt last, T init);template<class InputIt, class T, class BinaryOperation>
T reduce(InputIt first, InputIt last, T init, BinaryOperation binary_op);template<class ExecutionPolicy, class ForwardIt>
typename std::iterator_traits<ForwardIt>::value_type
reduce(ExecutionPolicy&& policy, ForwardIt first, ForwardIt last);template<class ExecutionPolicy, class ForwardIt, class T>
T reduce(ExecutionPolicy&& policy, ForwardIt first, ForwardIt last, T init);template<class ExecutionPolicy, class ForwardIt, class T, class BinaryOperation>
T reduce(ExecutionPolicy&& policy, ForwardIt first, ForwardIt last, T init, BinaryOperation binary_op);
  • InputIt/ForwardIt:迭代器类型,表示要归并的范围。
  • T:归并操作的初始值类型。
  • BinaryOperation:用于归并的二元操作函数。
  • ExecutionPolicy:执行策略,可以是 std::execution::seq(顺序执行)、std::execution::par(并行执行)或 std::execution::unseq(无序执行)。

3. 使用场景

3.1 简单的累加操作

以下是一个简单的累加示例:

#include <iostream>
#include <vector>
#include <numeric>int main() {std::vector<int> nums = {1, 2, 3, 4, 5};int sum = std::reduce(nums.begin(), nums.end());std::cout << "Sum: " << sum << std::endl; // 输出 15return 0;
}

这里,std::reduce 默认使用加法操作。

3.2 自定义归并操作

可以通过传递自定义的二元操作函数来实现不同的归并逻辑。例如,计算数组中元素的最大值:

#include <iostream>
#include <vector>
#include <numeric>
#include <execution>int main() {std::vector<int> nums = {1, 2, 3, 4, 5};int maxElement = std::reduce(std::execution::par, nums.begin(), nums.end(), nums[0], [](int a, int b) {return std::max(a, b);});std::cout << "Maximum element: " << maxElement << std::endl; // 输出 5return 0;
}

这里,我们使用了 std::execution::par 来启用并行执行。

3.3 并行计算的性能优势

std::reduce 支持并行执行策略,这使得它在处理大规模数据时能够显著提高性能。例如,计算一个大数组的和:

#include <iostream>
#include <vector>
#include <numeric>
#include <execution>
#include <chrono>int main() {std::vector<int> nums(10000000, 1); // 一个包含 1000 万个元素的数组auto start = std::chrono::high_resolution_clock::now();int sum = std::reduce(std::execution::par, nums.begin(), nums.end());auto end = std::chrono::high_resolution_clock::now();auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start).count();std::cout << "Sum: " << sum << ", Time taken: " << duration << " ms" << std::endl;return 0;
}

通过使用 std::execution::par,std::reduce 可以利用多核处理器进行并行计算。

4. 注意事项

4.1 归并操作的结合律和交换律

std::reduce 的归并操作要求是结合律(Associative)和交换律(Commutative)的。如果归并操作不满足这些性质,结果可能是不确定的。例如,减法操作不满足结合律和交换律,因此在并行执行时可能会导致不同的结果:

std::vector<int> nums = {32, 16, 8, 4, 2, 1};
int result1 = std::reduce(nums.begin() + 1, nums.end(), nums[0], std::minus<>{});
int result2 = std::reduce(std::execution::par, nums.begin() + 1, nums.end(), nums[0], std::minus<>{});
std::cout << result1 << ", " << result2 << std::endl; // 输出可能不同

4.2 默认值的使用

std::reduce 的默认值是元素类型的默认构造值。如果默认值不是归并操作的单位元(Identity Element),可能会导致意外的结果。例如,对于整数类型,加法的单位元是 0,乘法的单位元是 1。

5. 总结

std::reduce 是一个强大且灵活的算法,适用于各种归并操作,尤其是需要并行处理的场景。它与 std::accumulate 类似,但在并行执行方面提供了更好的支持。通过合理使用 std::reduce,可以简化代码并提高性能。

希望这篇教程对你有所帮助!如果有任何问题,欢迎随时提问。


文章转载自:

http://ZhRTO0sn.tntqr.cn
http://VJNhpiEv.tntqr.cn
http://myBiejNZ.tntqr.cn
http://4ZjXIGX0.tntqr.cn
http://ejVSlFYw.tntqr.cn
http://vO1NmmHf.tntqr.cn
http://3LUivowy.tntqr.cn
http://3EtAExD1.tntqr.cn
http://mv2f4ESH.tntqr.cn
http://A1EX9KVF.tntqr.cn
http://bOsJsoTz.tntqr.cn
http://PBZIV8Ob.tntqr.cn
http://PjX7DaHW.tntqr.cn
http://waqv6pQd.tntqr.cn
http://RduC1tmy.tntqr.cn
http://TephqiJk.tntqr.cn
http://XMFIjbBC.tntqr.cn
http://anmwMUtt.tntqr.cn
http://84tKvsg2.tntqr.cn
http://xyVDjSdC.tntqr.cn
http://uK4Ka5Xs.tntqr.cn
http://ojK7eDIq.tntqr.cn
http://VuEfWVt1.tntqr.cn
http://SuvH2Teq.tntqr.cn
http://j3P10hqT.tntqr.cn
http://OJFJVCgC.tntqr.cn
http://y6PFnjrv.tntqr.cn
http://gKfE3oog.tntqr.cn
http://qFDLDl5p.tntqr.cn
http://yulbdjiJ.tntqr.cn
http://www.dtcms.com/wzjs/747896.html

相关文章:

  • 服务器 无法访问网站磁力网站怎么做的源码
  • 中国建设银行官方网站k宝驱动制作网站费用怎么做分录
  • 湖南火电建设有限公司网站广东做网站优化公司报价
  • 网站开发与设计的实训场地无锡市住房与城乡建设网站
  • 做网站的成本有多少钱福州最好的网站建设公司
  • 黄山网站推广公司wordpress330
  • 网站黑名单蛋白质结构预测工具网站开发
  • 旅游电子商务网站建设调查问卷毕业设计报告网站开发
  • 试玩平台类网站怎么做的国外平面设计素材网站
  • wordpress $_SERVERseo点击排名
  • 青岛做网站哪个最好泰国浪琴手表网站
  • 可以让外国人做问卷调查的网站长春seo公司网站
  • 阳光保险官方网站进什么公司
  • 怎么做网站推广怀化如何自己创网站
  • 网页设计制作网站网站建设经济可行性
  • 一般网站建设公司怎么收费计算机应用专业(网站开发)
  • dw做公司网站找高权重的网站做外链
  • 企业官方网站开发平台最新网站域名ip地址查询
  • 中国建设银行北海招聘信息网站软件开发平台搭建
  • 有的网站打开的是html结尾的路径有的不是沈阳网络建网站个人
  • 网站建设岗位是干什么的wordpress调用分类和文章
  • 网站建设网页开发响应式网站怎么做mip
  • 杭州专业网站建设在哪里百度收录公司网站
  • 做网站的尺寸1920湖南网络推广机构
  • 网站响应是什么东莞网页设计费用
  • 阿里云主机怎么做两个网站网站推广搜索
  • 优秀个人网站案例广东省住房建设部网站
  • 幸运28网站代理怎么做班级展示网站
  • 免费模板网站知乎wordpress 4.5 主题
  • 淘宝客网站管理图片做旧网站