服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++ STL 中的数值算法示例讲解

C++ STL 中的数值算法示例讲解

2022-11-03 14:59Aatrowen C/C++

本片文章讲解了C++STL 中的数值算法,包含iota、accumulate、adjacent_difference、inner_product、partial_sum这些方法的使用,感兴趣的朋友来看看吧

以下算法均包含在头文件 numeric 中

1.iota

该函数可以把一个范围内的序列从给定的初始值开始累加
先看用法。
例:
假设我需要一个长度为10,从5开始递增的序列

?
1
2
3
4
5
6
vector<int> a(10);
iota(begin(a), end(a), 5);
 
for (auto x : a) {
    cout << x << " ";
}

输出:

5 6 7 8 9 10 11 12 13 14

这样就可以很方便的创建一个递增的序列,而不用使用for循环
此外,该函数是使用连续的支持 operator++()的 T 类型值填充序列
也就是说double类型也可以使用,string类型也可以使用。
只要是重载了++运算符的类型都可以使用。

2.accumulate

曾经在算法比赛中看见别人使用accumulate函数计算出了一个数组的和。
觉得特别的优雅,像这样:

?
1
2
3
4
vector<int> a(10);
iota(begin(a), end(a), 1);
 
cout << accumulate(begin(a), end(a), 0) << "\n"// 计算从1加到10的和,从0开始加

输出:

55

从那天起,每当我要求一个序列的和的时候,我都会使用这个方法...
但是今天,当我看到accumulate的源码之后:

?
1
2
3
4
5
6
7
8
9
template <class InputIterator, class T>
   T accumulate (InputIterator first, InputIterator last, T init)
{
  while (first!=last) {
    init = init + *first;  // or: init=binary_op(init,*first) for the binary_op version
    ++first;
  }
  return init;
}

注意看这里:

C++ STL 中的数值算法示例讲解

哇哦,它竟然还支持二元仿函数,详解C++ functional库中的仿函数使用方法
于是,我有了一个大胆的想法。
求一个数组的乘积

?
1
2
3
4
vector<int> a(10);
iota(begin(a), end(a), 1);
 
cout << accumulate(begin(a), end(a), 1, multiplies<int>()) << "\n"// 计算从1加到10的乘积,从1开始乘

输出:

3628800

同理,还可以求数组的减,数组的除,数组的模

3.partial_sum

这个函数可以用来求前缀和,前缀和指一个数组的某下标之前的所有数组元素的和(包含其自身)。

例如,1、2、3、4、5的前缀和数组为 1 3 6 10 15

?
1
2
3
4
5
6
7
8
vector<int> a(5);
iota(begin(a), end(a), 1);
 
partial_sum(begin(a), end(a), begin(a)); // 求a的前缀和,赋值给a数组(第三个参数)
 
for (auto x : a) {
    cout << x << " ";
}

输出:

1 3 6 10 15

有了上一个函数的经验,我们还可以求一个数组的前缀乘、除等

例:

?
1
partial_sum(begin(a), end(a), begin(a), multiplies<int>());

输出:

1 2 6 24 120

4.adjacent_difference

这个函数可以对一个序列里相邻两个元素进行运算,通过differerce这个词可以看出来,默认是计算相邻两元素的差

?
1
2
3
4
5
6
7
vector<int> a{1, 4, 5, 100, 40};
 
adjacent_difference(begin(a), end(a), begin(a)); // 求a数组相邻元素的差,赋值给a数组(第三个参数)
 
for (auto x : a) {
    cout << x << " ";
}

输出:

1 3 1 95 -60

今天我想计算相邻两元素的乘积

?
1
adjacent_difference(begin(a), end(a), begin(a), multiplies<int>());

输出:

1 4 20 500 4000

5.inner_product

这个函数默认情况下可以求序列中每个元素的内积之和:

?
1
2
3
4
vector<int> a(3);
iota(begin(a), end(a), 1);
 
cout << inner_product(begin(a), end(a), begin(a), 10) << "\n"; // 从初值10开始加上序列各元素的内积

输出:

24

还可以用来求两个序列元素两两相乘再相加的结果

?
1
2
3
4
5
vector<int> a{1, 2, 3};
vector<int> b{2, 3, 4};
 
// 1 * 2 + 2 * 3 + 3 * 4
cout << inner_product(begin(a), end(a), begin(b), 0) << "\n";

输出:

20

此外,还可以通过仿函数来替代上述的两个操作符 + 和 *

?
1
2
3
4
5
6
7
vector<int> a{1, 2, 3};
vector<int> b{2, 3, 4};
 
cout << inner_product(begin(a), end(a), begin(b), 1
                    , multiplies<int>(), minus<int>()) << "\n";
                        // 原来的加法 +  // 原来的乘法 *
                        // 计算 (1 - 2) * (2 - 3) * (3 - 4) = -1

输出:

-1

到此这篇关于C++ STL 中的数值算法示例讲解的文章就介绍到这了,更多相关C++ 数值算法内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/Aatrowen-Blog/p/16114383.html

延伸 · 阅读

精彩推荐
  • C/C++C语言 常量详解及示例代码

    C语言 常量详解及示例代码

    本文主要讲解C语言 常量,这里整理了 C语言常量的基础知识,并附代码示例和示例详细讲解,希望能帮助开始学习C 语言的同学...

    C语言教程网10422021-04-13
  • C/C++关于C++一些特性的探究

    关于C++一些特性的探究

    下面小编就为大家带来一篇关于C++一些特性的探究。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    C++教程网11552021-04-06
  • C/C++C语言键盘控制走迷宫小游戏

    C语言键盘控制走迷宫小游戏

    这篇文章主要为大家详细介绍了C语言键盘控制走迷宫小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    Kingdeguo11052021-09-10
  • C/C++使用C++实现顺序链表

    使用C++实现顺序链表

    今天小编就为大家分享一篇关于使用C++实现顺序链表,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    Struggler094722021-07-12
  • C/C++C++ OpenCV绘制几何图形

    C++ OpenCV绘制几何图形

    这篇文章主要为大家详细介绍了C++ OpenCV绘制几何图形,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    onlyloveyd9242022-02-17
  • C/C++C++中临时对象的常见产生情况及其解决的方案

    C++中临时对象的常见产生情况及其解决的方案

    这篇文章主要是探讨常见的临时对象产生的情况,及其如何避免和解决这种临时对象产生的方式。具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    呋喃吖10942022-01-05
  • C/C++C++中 string 中的常用方法使用心得

    C++中 string 中的常用方法使用心得

    这篇文章主要介绍了C++中 string 中的常用方法使用心得,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的...

    maoqifan4122021-08-29
  • C/C++Qt实现简易时钟

    Qt实现简易时钟

    这篇文章主要为大家详细介绍了Qt实现简易时钟,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    PlanetRT4332021-09-15