五 STL算法(一)数值算法

本文介绍了STL标准库中的核心数值算法,包括accumulate、adjacent_difference、inner_product及partial_sum等函数的功能与用法,并简述了SGI STL额外提供的power与itoa算法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一  概述:

使用数值算法需要包含头文件<numeric>,但它们实际定义于<bits/stl_numeric.h>中。


二 相关算法:


(1)accumulate:用来计算[first,last)内所有元素和init的值的总和。如果希望计算[first,last)中所有数值的总和,应该把init设置为0。

accumulate的定义:

//版本1

template<class InputIterator,class T>

T accumulate(InputIterator first,InputIterator last,T init);

//版本2

template<class InputIterator,class T,class BinaryOperation>

T accumulate(InputIterator first,InputIterator last,T init,BinaryOperation binary_op);


(2)adjacent_difference:用来计算[first,last)中相邻元素的差额。


(3)inner_product:计算[first1,last1)和[firs2t,first2+(last1-first1))的一般内积。


(4)partial_sum:计算局部总和。


以上四个是STL标准提供的,SGI STL还提供了以下两个(不在stl_numeric.h头文件中定义):


(5)power:用来计算某数的n幂次方,这类所谓的n幂次方是指自己对自己进行某种运算到达n次。


(6)itoa:设定某个区间的内容,使其内的每一个元素从指定的value值开始,呈现递增状态。





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值