0

0

c++中如何使用std::inclusive_scan_c++17包含前缀和用法【实例】

穿越時空

穿越時空

发布时间:2026-01-23 05:55:24

|

285人浏览过

|

来源于php中文网

原创

std::inclusive_scan是C++17计算包含自身的前缀和的并行算法,要求输出空间预先分配且支持自定义二元操作;输入输出可重叠但仅允许向后覆盖,与exclusive_scan的核心区别在于是否包含当前元素。

c++中如何使用std::inclusive_scan_c++17包含前缀和用法【实例】

std::inclusive_scan 是 C++17 引入的并行算法(定义在 中),用于计算**包含自身**的前缀和(即每个位置结果 = 从首元素到当前元素的累加值)。它比手写循环更安全、可读性更好,且支持自定义二元操作和输出迭代器。

std::inclusive_scan 基本用法与参数含义

函数签名如下:

template>
OutputIt inclusive_scan(InputIt first, InputIt last,
                        OutputIt d_first, BinaryOp binary_op = {});

关键点:

  • first / last:输入范围,左闭右开,要求可随机访问或至少前向迭代器
  • d_first:输出起始位置,**必须保证足够空间**(否则行为未定义)
  • binary_op:默认是 std::plus(),即加法;也可传入 std::multiplies()、lambda 等
  • 返回值是输出末尾的迭代器(d_first + (last - first)),通常可忽略

常见错误:输出空间不足或重叠导致未定义行为

最容易踩的坑是直接对原容器做“原地扫描”——比如传入 v.begin() 作为 d_first,但没确认是否允许重叠。标准规定:输入与输出范围可以重叠,但仅当输出范围起始 ≥ 输入范围起始时才安全(即只能向后覆盖)。

立即学习C++免费学习笔记(深入)”;

以下写法是**危险的**(向前覆盖,未定义):

std::vector v = {1, 2, 3, 4};
std::inclusive_scan(v.begin(), v.end(), v.begin() + 1); // ❌ 错误:v[1] 覆盖后影响后续计算

正确做法:

Replit Ghostwrite
Replit Ghostwrite

一种基于 ML 的工具,可提供代码完成、生成、转换和编辑器内搜索功能。

下载
  • 用独立输出容器(最安全)
  • 若需原地,确保 d_first == first(即从头开始覆盖)
  • 或使用 std::vector::resize() 预留空间

实例:整数前缀和 + 自定义乘积扫描

示例 1:标准前缀和

std::vector input = {2, 3, 1, 4};
std::vector output(input.size());
std::inclusive_scan(input.begin(), input.end(), output.begin());
// output == {2, 5, 6, 10}

示例 2:用 lambda 计算“前缀最大值”(注意这不是数学前缀和,但符合 inclusive_scan 语义)

std::vector a = {3, 1, 4, 1, 5};
std::vector max_prefix(a.size());
std::inclusive_scan(a.begin(), a.end(), max_prefix.begin(),
                    [](int x, int y) { return std::max(x, y); });
// max_prefix == {3, 3, 4, 4, 5}

与 std::exclusive_scan 的核心区别

std::inclusive_scan 包含当前元素;std::exclusive_scan 不包含(首元素输出为初值,默认 0)。例如输入 {1,2,3}

  • inclusive{1, 3, 6}
  • exclusive(默认初值 0)→ {0, 1, 3}

如果需要 exclusive 行为但又想用 inclusive_scan,可手动偏移:先 push 一个 0,再对 [1, end) 扫描,但不如直接用 exclusive_scan 直观。

真正容易被忽略的是:这两个函数都要求输出迭代器指向**已分配内存**,不会自动扩容 —— 这和 std::transform 一样,不是 std::back_inserter 那类插入型算法。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

50

2026.01.05

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

404

2023.08.14

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

30

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

393

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

116

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 7.2万人学习

C 教程
C 教程

共75课时 | 4.2万人学习

C++教程
C++教程

共115课时 | 13.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号