0

0

C++中std::exclusive_scan怎么用_C++17前缀和计算算法详解【数值】

穿越時空

穿越時空

发布时间:2026-02-05 11:45:11

|

894人浏览过

|

来源于php中文网

原创

std::exclusive_scan是C++17引入的并行算法,用于计算严格前缀和(即每个位置结果不含当前元素),适用于累积偏移量、构建索引映射表或预分配区间边界等场景。

c++中std::exclusive_scan怎么用_c++17前缀和计算算法详解【数值】

std::exclusive_scan 是什么,适合解决哪类问题

它是在 C++17 引入的并行算法,用于计算**严格前缀和**(即每个位置的结果不包含当前元素),等价于手动写循环做 out[i] = in[0] + in[1] + ... + in[i-1]。典型场景是:需要累积偏移量、构建索引映射表、或为后续并行操作预分配区间边界——比如把一组长度 {2, 5, 3} 转成起始偏移 {0, 2, 7}

基本用法与参数顺序不能错

函数签名是:std::exclusive_scan(first, last, d_first, init, binary_op)。最容易出错的是前三个迭代器参数顺序和 init 的含义:

  • firstlast 是输入范围,[first, last) 闭开区间
  • d_first 是输出起始位置,必须保证足够空间(至少 last - first 个元素)
  • init 是**首个输出值**,也就是 out[0],不是“初始累加值”——它直接赋给第一个结果,之后才开始累加
  • binary_op 可选,默认是 std::plus(),但若传了就必须显式写出类型,比如 std::multiplies()

示例:

std::vector v = {1, 2, 3, 4};
std::vector out(v.size());
std::exclusive_scan(v.begin(), v.end(), out.begin(), 0); // out == {0, 1, 3, 6}

和 std::inclusive_scan、std::partial_sum 的关键区别

三者都算前缀和,但语义不同:

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

玄鲸Timeline
玄鲸Timeline

一个AI驱动的历史时间线生成平台

下载
  • std::exclusive_scan:结果中第 i 项 = 前 i 项和(不含第 i 项),长度同输入,首项由 init 指定
  • std::inclusive_scan:结果中第 i 项 = 前 i+1 项和(含第 i 项),首项 = 输入首项
  • std::partial_sum(C++98 就有):行为等价于 inclusive_scan,但不支持自定义二元操作的并行执行,也不接受 init

如果误把 exclusive_scan 当作 partial_sum 用,会发现结果整体右移一位且首项多出一个 0,这是最常被忽略的语义偏差。

实际使用时容易踩的坑

几个高频问题:

  • 输出容器没预留空间,导致 d_first 迭代器失效(尤其用 back_inserter 时不行,必须提前 resize 或用 vector 构造)
  • 对浮点数使用默认 std::plus 时,未考虑结合律失效带来的精度差异(并行执行下求和顺序不确定)
  • 传入 binary_op 但没指定模板参数,如写成 std::exclusive_scan(..., 0, std::multiplies) 会编译失败,必须写 std::multiplies()std::multiplies()
  • 输入/输出范围重叠且非同一容器时,行为未定义;同一容器上原地计算需确保是 exclusive_scaninclusive_scan 不允许原地)

真正要靠它提速,得配合执行策略,比如加 std::execution::par_unseq;但小数据量反而更慢,别盲目加。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
页面置换算法
页面置换算法

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

425

2023.08.14

AO3官网入口与镜像站汇总 Archive of Our Own访问路径及最新入口
AO3官网入口与镜像站汇总 Archive of Our Own访问路径及最新入口

本专题专注于提供Archive of Our Own (AO3) 的最新官网入口与镜像站地址,详细整理了可用的访问路径,包括中文镜像站入口和网页版直达链接,帮助用户轻松找到最稳定的访问方式,确保顺畅浏览AO3内容。

1

2026.02.05

192.168.1.1路由器后台管理入口与设置登录指南
192.168.1.1路由器后台管理入口与设置登录指南

本专题汇总了192.168.1.1路由器的后台管理入口、登录网址以及无线网络设置的方法,帮助用户快速进入路由器管理页面,进行网络配置、密码修改等常见操作,提升家庭网络的管理与优化效率。

1

2026.02.05

Python 数据库优化与性能调优
Python 数据库优化与性能调优

本专题专注讲解 Python 在数据库性能优化中的应用,包括数据库连接池管理、SQL 查询优化、索引设计与使用、数据库事务管理、分布式数据库与缓存系统的结合。通过分析常见性能瓶颈,帮助开发者掌握 如何优化数据库操作,提升 Python 项目在数据库层的响应速度与处理能力。

1

2026.02.05

Java 微服务与 Spring Cloud 实战
Java 微服务与 Spring Cloud 实战

本专题讲解 Java 微服务架构的开发与实践,重点使用 Spring Cloud 实现服务注册与发现、负载均衡、熔断与限流、分布式配置管理、API Gateway 和消息队列。通过实际项目案例,帮助开发者理解 如何将传统单体应用拆分为高可用、可扩展的微服务架构,并有效管理和调度分布式系统中的各个组件。

0

2026.02.05

C++ 多线程编程与线程池设计
C++ 多线程编程与线程池设计

本专题深入讲解 C++ 中的多线程编程与线程池设计,涵盖 C++11/14/17 的线程库、线程同步机制(mutex、condition_variable、atomic)、线程池设计模式、任务调度与优化、并发瓶颈分析与解决方案。通过多个实际案例,帮助开发者掌握 如何设计高效的线程池管理系统,提升 C++ 程序在高并发场景下的性能与稳定性。

0

2026.02.05

微信网页版文件传输助手教程合集
微信网页版文件传输助手教程合集

本专题整合了微信网页版文件传输助手教程、入口等等内容,阅读专题下面的文章了解更多详细内容。

16

2026.02.04

微信文件过期恢复教程
微信文件过期恢复教程

本专题整合了微信文件过期恢复方法、技巧教程,阅读专题下面的文章了解更多详细内容。

10

2026.02.04

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

96

2026.02.04

热门下载

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

精品课程

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

共94课时 | 8.6万人学习

C 教程
C 教程

共75课时 | 4.5万人学习

C++教程
C++教程

共115课时 | 15.9万人学习

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

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