C++:STL常用算法随笔

news2024/10/6 1:45:24

主要的头文件#include <algorithm>  < functional>  <numeric>

遍历算法:

for_each、transform(搬运容器到另一个容器中 )

void print1(int val)
{
    cout << val <<" ";
}
for_each (v.begin(),v.end() , print1)

或者用仿函数的形式遍历:

class print2{
public:
    void operator()(int val)
    {
        cou <<val <<" ";
    }
}

for_each(v.begin(),v.end(),print2()) ;  不同于上述,此处需要传入匿名函数对象


对于transform搬运算法:

vector <int> vtarget;   //创建目标容器

vtarget.resize(v.size()) ; //目标容器必须提前开辟空间,与原vector一致,否则无法搬运

class trans1{
public :
    int operator () (int val )
    {
        return val;    
    }
}

transform (v.begin();v.end();vtarget.begin(),trans1());  //最后需要加个仿函数 ,注意中间的vtarget.begin()迭代器

查找算法:

find         //查找元素  ,找到返回指定元素的迭代器,找不到返回结束迭代器end();

                利用find可以在容器中找指定的元素,返回值是迭代器,使用迭代器接收
find_if        //按条件查找元素 ,三个参数:开始迭代器、结束迭代器、谓词(返回bool的仿函数)

vector<int>::iterator it = find_if(v.begin(), v.end(), GreaterFive());
if (it ==v.end()) {...}  //没找到
else{} ;  //找到了

对于查找自定义数据类型:

class Person{

public:
    person(string name ,int age){

    this->m_Name = name;
    this->m_Age = age;
}
public:
    string m_Name;
    int m_Age ;
};

class Greater{
    bool operator()(Person &p){
    return p.m_Age >20;    
}
}

 
vector <Person>::iterator it  = find_if (v.begin() , v.end() , Greater());
if(it == v.end()){};
else {};

adjacent_find        //查找相邻重复元素,返回相邻重复元素的第一个元素迭代器

vector<int>::iterator pos = adjacent_find(v.begin(), v.end());


binary_search        //二查找法,查找指定元素是否存在,但是只能在有序数组中使用,返回一个bool类型,速度快,logN时间复杂度
bool ret =binary_search(v.begin(),v.end(),9 ) //查找容器中是否有9元素,但是只能是升序,降序需要提供重载版本

  //升序
    vector<int> v;
    for (int i = 0; i < 10; i++) {
        v.push_back(i);
            }
    bool ret = binary_search(v.begin(), v.end(), 8);
    if (ret == true) {
        cout << "true" << endl;
    }
    else {
        cout << "false" << endl;
    }

    //测试降序是否适用
    vector<int> v1;
    for (int i = 10; i > 0; i--) {
        v1.push_back(i);
    }
    bool ret2 = binary_search(v1.begin(), v1.end(), 8);
    if (ret2 == true) {
        cout << "true" << endl;
    }
    else {
        cout << "false" << endl;
    }

//结果输出:
true
false


count        //统计元素个数,返回一个int整形。

int num=count(v.begin(),v.end(),40);
count_if        //按条件统计元素个数

int num = count_if (v.begin(),v.end(),Greater())  ; 最后一个参数为谓词

或者自定义数据类型:

 排序算法:

sort(v.begin(),v.end()); //升序排列,降序需要添加<functional>中的模板

void myPrint(int val)

{cout << val <<" ";}

sort(v.begin(),v.end(),greater<int>());

for_each (v.begin(),v.end(),myPrint);

打乱算法:random_shuffle

srand((unsigned int) time (NULL));   // 使用时间作为随机数种子来确保真正的随机

random_shuffle(v.begin(),v.end());

合并算法:merge(前提两个容器必须有序,合并之后的也是有序的)

//目标容器
vector<int>vTarget;

vTarget.resize(v1.size()+v2.size()); // 前提必须要给目标容器分配内存!!!
merge(v1.begin(),v1.end(),v2.begin(),v2.end(),vTarget.begin());

数据反转:reverse

reverse(v.begin,v.end());

拷贝和替换算法:

vector <int> v2;

v2.resize(v1.size());  //注意记得先开辟空间!

copy(v1.begin(),v1.end(),v2.begin());

替换算法:replace 

replace(v1.begin(),v1.end() ,20  , 2000) ; // 把所有的20替换为2000

按照条件替换:replace_if

一般构建仿谓词来作为参数

构建谓词(把大于等于30 的数替换)

class Greater30

{

public :
        bool operator() (int val )

        {

                return val>=30;

        }

}

replace_if (v1.begin() , v1. end() , Greater30() ,30000) ; 把大于等于30的数替换为30000;

常用算数生成算法:#include <numeric>

accumulate   // 计算容器元素累计总和,可以设置起始值
fill // 向容器中添加元素,填充所有空间为指定的值

int sum = accumulate(v.begin() , v.end() , value);  //value 表示起始的累加值

常用的集合算法: (此处的集合并不指set容器,而是数学概念)

求交集: set_ intersection    (原容器必须是有序序列)

vector <int> vtarget;

vtarget.resize(min(v1.size(),v2.size())) ;  //这样做是考虑到最大的目标容器内存情况:原容器1包含原容器2

vector<int>::interator itEnd=set_ intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),vtarget.begin());  //返回迭代器,指向新的vtarget的最后
打印输出:
for_each (vTarget.begin(),itEnd , myprint());

求并集 : set_union(原容器必须是有序序列)

vtarget.resize(v1.size()+v2.size()) ;  //这样做是考虑到最大的目标容器内存情况:原容器1与原容器2无交集

vector<int>::interator itEnd=set_ union(v1.begin(),v1.end(),v2.begin(),v2.end(),vtarget.begin());  //返回迭代器,指向新的vtarget的最后

打印输出:
for_each (vTarget.begin(),itEnd , myprint());

求差集 : set _difference

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2190912.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NVIDIA网卡系列之ConnectX-6 DX规格信息(200G-PCIe 4.0x16-8PF1000VF-2019年发布)

背景 NVIDIA ConnectX-6是最大支持200G的产品&#xff0c;有DX LX等系列。LX一般是25G比较便宜。 核心关键点 200GbpsPCIe 4.0&#xff0c;最大lane: x16 (4.0的lane速 16GT/s * 16 256T/s&#xff0c;所以支持的是200G的网卡用PCIe4.0)QSFPPF&#xff0c;VF数量&#xff1…

Linux 传输层UDP

文章目录 一、再谈端口号查看知名端口号和网站的强关联信息&#xff1f;一个进程是否可以bind多个端口号&#xff1f;一个端口号是否可以被多个进程bind&#xff1f;理解进程和端口的关系&#xff1f; 二、UDP协议协议格式16位源端口号&#xff1a;16位目的端口号&#xff1a;1…

双指针:滑动窗口

题目描述 给定两个字符串 S 和 T&#xff0c;求 S 中包含 T 所有字符的最短连续子字符串的长度&#xff0c;同时要求时间复杂度不得超过 O(n)。 输入输出样例 输入是两个字符串 S 和 T&#xff0c;输出是一个 S 字符串的子串。样例如下&#xff1a; 在这个样例中&#xff0c…

计算机网络:物理层 —— 物理层下的传输媒体

文章目录 传输媒体导向性媒体同轴电缆双绞线光纤光纤分类中心波长光纤规格光纤的优缺点 非导向性媒体ISM 频段无线电波微波激光红外线可见光 传输媒体 传输媒体是计算机网络设备之间的物理通路&#xff0c;也称为传输介质或传输媒介&#xff0c;并不包含在计算机网络体系结构中…

408笔记|随笔记录|自用|2

文章目录 cache和TLB查找总结 接上篇选择题 打开同一个文件共享同一个内存索引结点 cache和TLB cache由SRAM组成&#xff0c;TLB通常由相联存储器组成&#xff0c;可以由SRAM组成。 DRAM需要不断刷新&#xff0c;性能比较低。 TLB缺失可以由软件或者硬件处理&#xff0c;cac…

JC系列CAN通信说明

目录 一、CAN协议二、指令格式三、通信接线3.1、一对一通信3.2、组网通信 四、寄存器定义五、指令说明4、读取电源电压5、读取母线电流6、读取实时速度8、读取实时位置10、读取驱动器温度11、读取电机温度12、读取错误信息32、设定电流33、设定速度35、设定绝对位置37、设定相对…

Java-进阶二

ArrayList的源代码分析&#xff08;扩容原理&#xff09; 1 使用空参构造的集合&#xff0c;在底层创建一个容量为0的数组。2 添加第一个元素时&#xff0c;底层会扩容创建一个容量为10的数组。3 存满时会扩容1.5倍。4 如果一次添加多个元素&#xff0c;1.5倍还放不下&#xff…

机器学习/数据分析--用通俗语言讲解时间序列自回归(AR)模型,并用其预测天气,拟合度98%+

时间序列在回归预测的领域的重要性&#xff0c;不言而喻&#xff0c;在数学建模中使用及其频繁&#xff0c;但是你真的了解ARIMA、AR、MA么&#xff1f;ACF图你会看么&#xff1f;&#xff1f; 时间序列数据如何构造&#xff1f;&#xff1f;&#xff1f;&#xff0c;我打过不少…

提升客户满意度,数字化售后工单系统的实施策略

售后工单系统助企业优化运营&#xff0c;提升客户满意度。涵盖技术支持、维修服务、客户反馈管理等应用场景。ZohoDesk凭高效定制成企业首选。未来趋势包括AI、物联网、AR/VR技术集成&#xff0c;提升服务智能化水平。 一、售后工单系统的重要性 售后工单系统是企业用来管理和…

基于Java的GeoTools对Shapefile文件属性信息深度解析

目录 前言 一、Shapefile的属性列表信息 1、属性表格信息 2、属性表格包含的要素 二、GeoTools对属性表格的解析 1、常规解析方法 2、基于dbf文件的属性信息读取 三、总结 前言 ESRI Shapefile&#xff08;shp&#xff09;&#xff0c;或简称shapefile&#xff0c;是美…

SQL优化 - 排序

文章目录 排序和索引降序索引 FilesortORDER BY 顺序问题ORDER BY LIMIT 排序和索引 如果ORDER BY操作使用了索引&#xff0c;那么就可以避免排序操作&#xff0c;因为索引本身就是按索引 key 排好序的。那什么情况下&#xff0c;ORDER BY会走索引呢&#xff1f; 例如&#…

专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结

目录 搜索 vs 深度优先遍历 vs 深度优先搜索 vs 宽度优先遍历 vs 宽度优先搜索 vs 暴搜 1.深度优先遍历 vs 深度优先搜索(dfs) 2.宽度优先遍历 vs 宽度优先搜索(bfs) 2.关系图暴力枚举一遍所有的情况 3.拓展搜索问题全排列 决策树 1. 计算布尔⼆叉树的值&#xff08;medi…

CF2013E Prefix GCD

【题目大意】 给定一个长度为 n n n 的数列 a 1 … n a_{1 \dots n} a1…n​&#xff0c;你可以将 a 1 … n a_{1 \dots n} a1…n​ 按照任意顺序进行重排&#xff0c;使得&#xff1a; ∑ i 1 n gcd ⁡ { a 1 , a 2 , a 3 , … , a n } \sum\limits_{i1}^{n}\gcd\left \{…

10.5学习

1.GateWay GateWay⽬标是取代Netflflix Zuul&#xff0c;它基于Spring5.0SpringBoot2.0WebFlux等技术开发&#xff0c;提供统⼀的路由⽅式&#xff08;反向代理&#xff09;并且基于 Filter(定义过滤器对请求过滤&#xff0c;完成⼀些功能) 链的⽅式提供了⽹关基本的功能&…

探索 Python 虚拟环境的奥秘:virtualenv 的魔法世界

文章目录 探索 Python 虚拟环境的奥秘&#xff1a;virtualenv 的魔法世界背景&#xff1a;为何选择 virtualenv&#xff1f;虚拟环境的守护者&#xff1a;virtualenv 是什么&#xff1f;安装 virtualenv&#xff1a;简单几步&#xff0c;开启隔离之旅掌握 virtualenv 的基本用法…

Relu激活

ReLU&#xff08;Rectified Linear Unit&#xff09;激活函数 是卷积神经网络&#xff08;CNN&#xff09;以及许多深度学习模型中最常用的激活函数之一。它的主要作用是引入非线性&#xff0c;使模型能够学习和表达更复杂的特征。以下是对ReLU激活函数的详细解释。 1. ReLU的…

C语言进阶版第16课—自定义类型:结构体

文章目录 1. 结构体类型的声明和初始化2. 结构体自引用3. 结构体内存对齐3.1 结构体内存对齐规则3.2 修改默认对齐数 4. 结构体传参4. 结构体实现位段5. 位段使用的注意事项 1. 结构体类型的声明和初始化 结构体在使用之前都要对其类型进行声明&#xff0c;关键字是struct&…

15分钟学 Python 第36天 :Python 爬虫入门(二)

Python 爬虫入门&#xff1a;环境准备 在进行Python爬虫的学习和实践之前&#xff0c;首先需要准备好合适的开发环境。本节将详细介绍Python环境的安装、必要库的配置、以及常用工具的使用&#xff0c;为后续的爬虫编写奠定坚实的基础。 1. 环境准备概述 1.1 为什么环境准备…

mp4转gif在线转换怎么转?7个视频转动图方法不容错过!(超简单)

mp4转gif在线转换怎么转&#xff1f;如今&#xff0c;将mp4视频转换为gif动图格式&#xff0c;满足了人们对易于分享和网络传播内容的需求。与mp4视频相比&#xff0c;gif动图文件体积相对较小&#xff0c;几乎所有网络平台都支持这种格式&#xff0c;无需额外安装插件或软件。…

CSID-GAN:基于生成对抗网络的定制风格室内平面设计框架论文阅读

CSID-GAN: A Customized Style Interior Floor Plan Design Framework Based on Generative Adversarial Network 摘要前言II. CSID-GAN METHODA. Overall FrameworkB. Algorithm and Loss Function III. DATASETS AND EVALUATION METRICSA. DatasetsB. Evaluation Metrics IV.…