1. accumulate算法
accumulate
算法用于计算序列的总和(可以是数组、向量等)。它的基本用法如下:
#include <numeric>
#include <iostream>
#include <vector>
int main() {
std::vector<int> numbers = {1, 2, 3, 4, 5};
// 计算序列总和
int sum = std::accumulate(numbers.begin(), numbers.end(), 0);
std::cout << "Sum of the numbers: " << sum << std::endl;
return 0;
}
accumulate
接受三个参数:起始迭代器、终止迭代器以及初始值。这个算法遍历容器中的元素,将它们依次相加并返回总和。
2. fill算法
fill
算法用于将容器中的元素替换为指定的值
#include <algorithm>
#include <iostream>
#include <vector>
int main() {
std::vector<int> numbers(5); // 创建大小为5的向量
// 使用 fill 将向量中所有元素置为 10
std::fill(numbers.begin(), numbers.end(), 10);
// 打印修改后的向量
for (int num : numbers) {
std::cout << num << " ";
}
std::cout << std::endl;
return 0;
}
fill
方法的参数包括起始迭代器、终止迭代器以及要填充的值。它会将指定范围内的元素全部设置为给定的值。