C++ STL——常用算法
注:原创不易,转载请务必注明原作者和出处,感谢支持!
注:内容来自某培训课程,不一定完全正确!
一 常用查找算法
/*
find算法 查找元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param val 查找的元素
@return 返回查找元素的位置
*/
find(iterator beg, iterator end, val);
/*
adjacent_find算法 查找相邻重复元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param _callback回调函数或者谓词(返回bool类型的函数对象)
@return 返回相邻元素的第一个位置的迭代器
*/
adjacent_find(iterator beg, iterator end, _callback);
/*
binary_search算法 二分查找算法
注意:在无序序列中不可用
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param val 查找的元素
@return 找到返回true,否则返回false
*/
bool binary_search(iterator beg, iterator end, val);
/*
find_if算法 条件查找
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param _callback 回调函数或者谓词
@return 找到返回true,否则返回false
*/
find_if(iterator beg, iterator end, _callback);
/*
count算法 统计元素出现的次数
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param val 待统计元素
@return int返回元素的个数
*/
count(iterator beg, iterator end, val);
/*
count_if算法 统计元素出现的次数
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param _callback回调函数或者谓词
@return int返回元素的个数
*/
count_if(iterator beg, iterator end, _callback);
常用查找算法的应用案例。
// 基础数据类型的查找
void Test1()
{
vector<int> v1;
for (int i = 0; i < 10; ++i)
{
v1.push_back(i);
}
vector<int>::iterator ret = find(v1.begin(), v1.end(), 5);
if (ret != v1.end()) {
cout << "找到了!" << endl;
}
else {
cout << "没有找到!" << endl;
}
}
// 对象类型的查找,需要给对象重载==号运算符
class Person
{
public:
Person(int age, int id) : age(age), id(id) {}
// 必须给对象重载==号运算符,否则无法使用find()
bool operator==(const Person &p) { return this->id == p.id && this->age == p.age; }
public:
int age;
int id;
};
void Test2()
{
vector<Person> v;
Person p1(10, 20), p2(30, 40), p3(50, 60);
v.push_back(p1);
v.push_back(p2);
v.push_back(p3);
vector<Person>::iterator ret = find(v.begin(), v.end(), p2);
if (ret != v.end()) {
cout << "找到了p2!" << endl;
}
else {
cout << "没找到p2!" << endl;
}
}
// binary_search()二分查找
void Test3()
{
vector<int> v;
for (int i = 0; i < 10; ++i)
{
v.push_back(i);
}
bool ret = binary_search(v.begin(), v.end(), 5);
if (ret) {
cout << "找到了5!" << endl;
}
else {
cout << "没找到5!" << endl;
}
}
// find_if()
// count(),count_if()和find(),find_if()是类似的
bool MySearch(int val)
{
// 找到第一个大于5的值
return val > 5;
}
void Test4()
{
vector<int> v;
for (int i = 0; i < 10; ++i)
{
v.push_back(i);
}
// find_if会根据我们的条件(函数),返回第一个满足条件的元素的迭代器
vector<int>::iterator ret = find_if(v.begin(), v.end(), MySearch);
if (ret != v.end()) {
cout << "ret = " << *ret << endl;
}
else {
cout << "没找到!" << endl;
}
}
二 常用遍历算法
/*
for_each遍历算法 遍历容器元素
@param beg 开始迭代器
@param end 结束迭代器
@param _callback 函数回调或者函数对象
@return 函数对象
*/
for_each(iterator beg, iterator end, _callback);
/*
transform算法 将指定区间元素搬运到另一容器中
注意:transform不会给目标容器分配内存,所以需要我们提前分配好内存
@param beg1 源容器开始迭代器
@param end1 源容器结束迭代器
@param beg2 目标容器开始迭代器
@param _callback 函数回调或者函数对象
@return 返回目标容器迭代器
*/
transform(iterator beg1, iterator end1, iterator beg2, _callback);
遍历算法应用案例。
// transform
struct MyPlus
{
int operator()(int val)
{
return val;
}
};
void MyPrint(int val)
{
cout << val << " ";
}
void Test1()
{
vector<int> v1, v2;
for (int i = 0; i < 10; ++i)
{
v1.push_back(i);
}
v2.resize(50);
transform(v1.begin(), v1.end(), v2.begin(), MyPlus());
for_each(v2.begin(), v2.end(), MyPrint);
}
C++ STL——常用算法的更多相关文章
- [C++ STL] 常用算法总结
1 概述 STL算法部分主要由头文件<algorithm>,<numeric>,<functional>组成.要使用 STL中的算法函数必须包含头文件<alg ...
- 28.STL常用算法
#include <algorithm> 算法 常用版本 描述 返回Type std::find() find(_InIt _Fisrt,_InIt _Last, _Ty& _Va ...
- c++ STL常用算法使用方法
#include <string> #include <vector> #include <functional> #include <iostream> ...
- 常用的STL查找算法
常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...
- STL——配接器、常用算法使用
学习STL,必然会用到它里面的适配器和一些常用的算法.它们都是STL中的重要组成部分. 适配器 在STL里可以用一些容器适配得到适配器.例如其中的stack和queue就是由双端队列deque容器适配 ...
- C++ STL 常用算术和生成算法
C++ STL 常用算术和生成算法 accumulate() accumulate: 对指定范围内的元素求和,然后结果再加上一个由val指定的初始值. #include<numeric> ...
- C++ STL 常用排序算法
C++ STL 常用排序算法 merge() 以下是排序和通用算法:提供元素排序策略 merge: 合并两个有序序列,存放到另一个序列. 例如: vecIntA,vecIntB,vecIntC是用ve ...
- C++ STL 常用查找算法
C++ STL 常用查找算法 adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. ...
- C++ STL 常用遍历算法
C++ STL 常用遍历算法 STL的容器算法迭代器的设计理念 1) STL的容器通过类模板技术,实现数据类型和容器模型的分离 2) STL的迭代器技术实现了遍历容器的统一方法:也为STL的算法提供了 ...
随机推荐
- LCD1602 液晶
它是一种专门用来显示字母.数字.符号的点阵型液晶模块 它是由若干个5x7或者5x10的点阵字符位组成 引脚 时序 操作步骤 初始化 写命令(RS=L)设置显示坐标 写数据(RS=H) 指令 清屏: 指 ...
- STM32L1xx——ADC(中断/DMA)样例代码
此代码欲实现的功能是:使用中断或者DMA的方式采集滑动变阻器采集到的电压值,使用单ADC单通道采样! (由于不是直接需要电压,所以转换函数我就没列出来,可根据自身需要去网上查到转换的函数.) 代码结构 ...
- Cacti-0.8.8b详细安装及配置步骤
1. Cacti环境安装 1.1 安装LAMP环境 安装LAMP环境,当然,如果你有兴趣可以采用编译,我线上Mysql是编译的,其余是yum安装的.在这次实验采用yum安装. 关闭i ...
- Python之datetime模块
datatime模块重新封装了time模块,提供更多接口,提供的类有:date,time,datetime,timedelta,tzinfo. 1.date类 datetime.date(year, ...
- 【django】另一种思路代替nginx 的rewrite
需求:访问xx.com 跳转到xx.com/index 修改setting 同级别的urls.py 文件 from django.conf.urls import include, url from ...
- javascript弹出带文字信息的提示框效果
// position of the tooltip relative to the mouse in pixel // <html><head><meta charse ...
- 串口+RS485驱动
其实RS485不算什么协议,只是物理层做了差分传输,AB两线的电压差来表示0,1,0,1,可靠性和距离更加好,因此,一个串口外设只能作为半双工使用,而RS232是可以全双工的. max485模块可以直 ...
- hive数据仓库表设计之(矮宽表+高窄表)
昨天面对某客户域做表关联的时候发现了. 有两张相同内容的主表.但是表的设计结构并不相同: (每个领域都有主表,每次往这个领域(库)添加新表的时候一般都会join 主表,从而有唯一的主键id) 这两个表 ...
- mongodb命令---花样查询语句
闲言少叙 查出价格低于200的商品信息----包含商品名称,货物编号,价格,添加信息等 db.goods.find( {}}, {,,,} ) 商品分类不为3的商品 db.goods.find( {} ...
- 洛谷P1233 木棍加工【单调栈】
题目:https://www.luogu.org/problemnew/show/P1233 题意: 有n根木棍,每根木棍有长度和宽度. 现在要求按某种顺序加工木棍,如果前一根木棍的长度和宽度都大于现 ...