首页 > 编程语言 >C++之STL的algorithm(5)之生成算法(accumulate、fill)整理

C++之STL的algorithm(5)之生成算法(accumulate、fill)整理

时间:2024-04-03 17:29:05浏览次数:21  
标签:std map algorithm STL C++ int accumulate include fill

C++之STL的algorithm(5)之生成算法(accumulate、fill)整理

注:整理一些突然学到的C++知识,随时mark一下
例如:忘记的关键字用法,新关键字,新数据结构


C++ 的遍历算法整理


提示:本文为 C++ 中accumulate、fill 的写法和举例


一、生成算法

1、accumulate累加算法

accumulate 是 <numeric> 头文件中的一个算法,用于计算容器(或其他迭代器范围)中所有元素的累计总和。它也可以接受一个二元操作符,用于自定义元素的累积方式。

参数:

first, last:输入序列的开始和结束迭代器。
init:累积求和的初始值。
binary_op(可选):二元操作符,用于计算两个元素的和。默认为 std::plus<>(),即加法操作符。

返回值:

返回一个值,表示从 init 开始的累积结果。
示例:

对于 std::vector:

#include <iostream>  
#include <vector>  
#include <numeric>  
  
int main() {  
    std::vector<int> vec = {1, 2, 3, 4, 5};  
    int sum = std::accumulate(vec.begin(), vec.end(), 0); // 使用默认加法操作符  
    std::cout << "Sum of vector elements: " << sum << std::endl; // 输出:15  
    return 0;  
}

对于 std::map:
由于 std::map 存储的是键值对,通常我们不直接计算所有值的和,但如果你确实想这样做,你可以使用 std::accumulate 遍历 map 的值部分:

#include <iostream>  
#include <map>  
#include <numeric>  
  
int main() {  
    std::map<int, int> myMap = {{1, 10}, {2, 20}, {3, 30}};  
    int sum = std::accumulate(myMap.begin(), myMap.end(), 0,   
                               [](int init, const std::pair<int, int>& p) {  
                               return init + p.second; // 累加值  
                               });  
    std::cout << "Sum of map values: " << sum << std::endl; // 输出:60  
    return 0;  
}

对于 std::set:
通常 std::set 用于存储唯一的元素,而不常计算它们的和。但如果确实想计算 set 中所有元素的和(例如,如果 set 存储的是整数),可以这样做:

#include <iostream>  
#include <set>  
#include <numeric>  
  
int main() {  
    std::set<int> mySet = {1, 2, 3, 4, 5};  
    int sum = std::accumulate(mySet.begin(), mySet.end(), 0);  
    std::cout << "Sum of set elements: " << sum << std::endl; // 输出:15  
    return 0;  
}

2、fill 填充算法

fill 是 <algorithm> 头文件中的一个算法,用于向容器(或其他迭代器范围)中添加(或替换)相同的元素。

参数:

first, last:要填充的序列的开始和结束迭代器。
value:要填充的值。

返回值:

该函数没有返回值,但会修改传入的序列。

示例:

对于 std::vector:

#include <iostream>  
#include <vector>  
#include <algorithm>  
  
int main() {  
    std::vector<int> vec(5); // 创建一个包含5个元素的vector,默认初始化为0  
    std::fill(vec.begin(), vec.end(), 7); // 用7填充整个vector  
    for (int num : vec) {  
        std::cout << num << ' '; // 输出:7 7 7 7 7  
    }  
    std::cout << std::endl;  
    return 0;  
}

对于 std::map:
std::map 的元素是键值对,因此你不能简单地用 std::fill 填充整个 map。但你可以遍历 map 并修改其值部分:

#include <iostream>  
#include <map>  
#include <algorithm>  
  
int main() {  
    std::map<int, int> myMap = {{1, 10}, {2, 20}, {3, 30}};  
    for (auto& pair : myMap) {  
        pair.second
pair.second = 50; // 将所有值设置为50
}
// 使用 std::for_each 打印结果,因为 std::map 不保证顺序
std::for_each(myMap.begin(), myMap.end(), [](const std::pair<int, int>& p) {
std::cout << p.first << ": " << p.second << std::endl;
});
return 0;
}

对于 std::set: 由于 std::set 存储的是唯一的元素,你不能使用 std::fill 直接填充整个集合,因为这不符合集合的唯一性约束。

总结

标签:std,map,algorithm,STL,C++,int,accumulate,include,fill
From: https://blog.csdn.net/ULTRAmanTAROACE/article/details/137351932

相关文章

  • 执行计划中的NestLoop对比HashJoin对比
    执行计划中的nestloopjoin对比hashjoin两种join方式的定义NESTELOOP:在嵌套循环中,内表被外表驱动,外表返回的每一行都要在内表中检索找到与它匹配的行。两个概念:驱动表(外部表)和内部表,这里用表这个次其实不是很准确,外部表和内部表可以是某张表的结果集。在执行计划中如何区......
  • C++实现windows高精度微秒级延时(亲测可用)
    C++实现windows高精度微秒级延时(亲测可用)代码如下:#include<iostream>#include<windows.h>//定义一个结构体来保存性能计数器的频率和时间戳structPerformanceCounter{LARGE_INTEGERfrequency;//计数器频率LARGE_INTEGERstart;//开始时间......
  • 给c++小白的教程2:输出(1)
    想要输入代码,就必须打开新的源代码#include<bits/stdc++.h>usingnamespacestd;intmain(){ return0;}请萌新牢牢记住这段代码!!!要形成肌肉记忆!!!#include<bits/stdc++.h>是头文件,bits/stdc++.h是万能头,包括了c++里的绝大多数函数与数据结构usingnamespacestd;是命......
  • 【C++】string模拟实现
     ......
  • C++11中的正则表达式
    目录regexregex_match函数详解函数原型使用方法基本使用使用std::smatch获取更多信息注意事项regex_search函数详解函数原型使用方法基本使用使用std::smatch获取匹配信息注意事项regex_search和regex_match的区别regexC++11引入了<regex>头文件,它提供了对正则表达式的......
  • 【C/C++】VsCode调试配置tasks.json和launch.json
    前段时间配大作业环境改了很多配置,发现tasks.json和launch.json经常令自己很迷惑。网上找的配置有时会有各种各样的问题,在此记录一下上学期配好的配置文件,日后有时间再详细研究研究tasks.json:{"version":"2.0.0","tasks":[{"type":"shell",......
  • [c++] 小游戏 斗破苍穹2.7.1 版本 zty出品
    前言大家好,今天带来的是经典版本2.7.1这个版本在斗破苍穹中十分重要您好,欢迎您玩苍穹世界。为了给您更好的游戏体验,zty时不时会优化本游戏,优化后会尽快发布在网上。关于外挂方面,开启外挂的方式是设定勇者姓名时,输入“zty”(不包括双引号)。由于2.6.1版本的bug,我们在2.6.1的......
  • 【华为OD】2024年华为OD机试C卷真题集:最新的真题集题库 C/C++/Java/python/JavaScript
    【华为OD】2024年C卷真题集:最新的真题集题库C/C++/Java/python/JavaScript【华为OD】2024年C卷真题集:最新的真题集题库C/C++/Java/python/JavaScript-CSDN博客 2024年华为OD机试C卷真题题集题库,有2种分数的题目列表分别是100分的列表、200分的列表需要订阅请看链接:C卷......
  • C/C++的部分笔记
    C/C++部分笔记1、纯虚函数纯虚函数是一种特殊的虚函数,基类定义后(~=0)必须由派生类重写,纯虚函数将父类上升为一个抽象类,无法实例化对象;抽象类是指具有纯虚函数的类;一个基类说明有纯虚函数,该基类的派生类可以是抽象类;抽象类只能作为基类来使用,其纯虚函数的实现由派生类给出。......
  • 【C++】入门知识
    1.命名空间在C/C++中,变量、函数和后面要学到的类都是大量存在的,这些变量、函数和类的名称都将存在于全局作用域中,可能会导致很多冲突。使用命名空间的目的就是对标识符的名称进行本地化,以避免命名冲突或名字污染,namespace关键字的出现就是针对这种问题的。#include<iostre......