欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C++标准库笔记(一)

程序员文章站 2022-04-28 14:03:22
1、C++ STL中std::accumulate()、std::begin()和std::end() accumulate定义在#include中,实现的功能为:(1)用来计算指定范围内的元素之和。(2)指定的二进制操作计算特定范围内的元素结果。分别由两个函数模板实现: temp ......

1、c++ stl中std::accumulate()、std::begin()和std::end()

  accumulate定义在#include<numeric>中,实现的功能为:(1)用来计算指定范围内的元素之和。(2)指定的二进制操作计算特定范围内的元素结果。分别由两个函数模板实现:

  template <class inputiterator, class t>

     t accumulate (inputiterator first, inputiterator last, t init);

  template <class inputiterator, class t, class binaryoperation>

     t accumulate (inputiterator first, inputiterator last, t init, binaryoperation binary_op);

  各个参数说明:

    first            指定范围内第一个迭代的值或者结合操作选项使用。

    last            指定范围内最后一个迭代值或者结合操作项使用。

    init           要计算的初始值,也就是在累加之前给定的基础值。

    binary_op         运用于指定范围内所有元素和前面计算得到结果的参数。

      

#include <numeric>

#include <iostream>

#include <vector> using namespace std;

int main()

{
    vector<int> vec(10,1);

    int total = accumulate(vec.begin(),vec.end(),1000);

    cout<<"total:"<<total<<endl;

}

total:1010

 

 

 

   accumulate()等同于以下模板函数:

    

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;
}

 

 

 

  init既是初始值。

  

  模版函数std::begin、std::end,这两个模版函数可以作用于容器和数组,结合for_each()范围循环可以对容器逐个访问。

  //容器时使用
  template <class container>

  auto begin (container& cont) -> decltype (cont.begin());
    template <class container>
    auto begin (const container& cont) -> decltype (cont.begin());
    //数组时使用
  template <class t, size_t n>  t* begin (t(&arr)[n]); 

  例如:

  int array[] = {1,2,3,4,5,6};

  std::for_each(std::begin<int>(array), std::end<int>(array), [&](int n) {cout << n;}); //1,2,3,4,5,6。

 

  accumulate()结合std::begin()和std::end()使用

  以下是摘自网络的一段代码,求vector的均值和方差。

  

double sum = std::accumulate(std::begin(resultset), std::end(resultset), 0.0);  

double mean =  sum / resultset.size(); //均值 

double accum  = 0.0;  

std::for_each (std::begin(resultset), std::end(resultset), [&](const double d)

{  

    accum  += (d-mean)*(d-mean);  

});      

double stdev = sqrt(accum/(resultset.size()-1)); //方差