注:原创不易,转载请务必注明原作者和出处,感谢支持!

注:内容来自某培训课程,不一定完全正确!

一 常用查找算法

/*
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——常用算法的更多相关文章

  1. [C++ STL] 常用算法总结

    1 概述 STL算法部分主要由头文件<algorithm>,<numeric>,<functional>组成.要使用 STL中的算法函数必须包含头文件<alg ...

  2. 28.STL常用算法

    #include <algorithm> 算法 常用版本 描述 返回Type std::find() find(_InIt _Fisrt,_InIt _Last, _Ty& _Va ...

  3. c++ STL常用算法使用方法

    #include <string> #include <vector> #include <functional> #include <iostream> ...

  4. 常用的STL查找算法

    常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...

  5. STL——配接器、常用算法使用

    学习STL,必然会用到它里面的适配器和一些常用的算法.它们都是STL中的重要组成部分. 适配器 在STL里可以用一些容器适配得到适配器.例如其中的stack和queue就是由双端队列deque容器适配 ...

  6. C++ STL 常用算术和生成算法

    C++ STL 常用算术和生成算法 accumulate() accumulate: 对指定范围内的元素求和,然后结果再加上一个由val指定的初始值. #include<numeric> ...

  7. C++ STL 常用排序算法

    C++ STL 常用排序算法 merge() 以下是排序和通用算法:提供元素排序策略 merge: 合并两个有序序列,存放到另一个序列. 例如: vecIntA,vecIntB,vecIntC是用ve ...

  8. C++ STL 常用查找算法

    C++ STL 常用查找算法 adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. ...

  9. C++ STL 常用遍历算法

    C++ STL 常用遍历算法 STL的容器算法迭代器的设计理念 1) STL的容器通过类模板技术,实现数据类型和容器模型的分离 2) STL的迭代器技术实现了遍历容器的统一方法:也为STL的算法提供了 ...

随机推荐

  1. Java安全停止线程方法

    1. 早期Java提供java.lang.Thread类型包含了一些列的方法 start(), stop(), stop(Throwable) and suspend(), destroy() and ...

  2. 【Distributed】CDN

    一.概述 1.1 Web前端优化 1.2 DNS域名解析过程 1.3 传统方式请求静态资源 二.CDN内容分发 2.1 什么是CDN 2.2 CDN内容分发原理 2.3 阿里云环境实战搭建CDN内容分 ...

  3. JS__POST

    RSA加密 熟悉的东西 public key Encrypt (函数) 而且 每次刷新都会变化() 一般 128 位,也有 256位的

  4. c中fgets与strlen

    fgets函数从文件读取'\n'并存储,在'\n'后再增加一个'\0'构成字符串. 但fgets函数需要指定读入的字符数,如果指定了n,则最多只能读取n-1个.fgets在读取了n-1个字符.读到了' ...

  5. mysql tinyint(1) 在java中被转化为boolean

    数据库表字段类型为:tinyint 长度为1 在java中对应的类型是boolean 查询时直接在页面展示成true或false 如果是2,3,4 这样的也是默认成true,非常不友好. 解决方案: ...

  6. 网络编程基础之TCP学习(二)编程案例

    TCP网络编程流程如下: 实现功能:服务器端与客户端成功通讯后返回get! 服务器端程序 #include <netdb.h> #include <sys/socket.h> ...

  7. 【收藏】linux快速查找文件的技巧

    有时候,我们需要在系统中查找文件,Linux有一个非常优秀的搜寻系统. 一般提到搜寻文件的时候,很多人第一反应是find命令,但其实find不是常用的,因为速度慢,而且毁硬盘.一般我们都先用where ...

  8. java——从.net再学习java

    到底从java中学到了什么? 1,java是由sun公司发明的,sun希望制定一些标准,具体的实现交给具体的厂商来自己实现: 2,java是开源的,第三方做了很多自己的一些组件实现,比如: 很多时候, ...

  9. redis——redis的一些核心把握

    redis单线程,为什么比较快 单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程处理所有网络请求,其他模块仍用了多个线程.redis能够快速执行的原因有三点: (1) 绝大 ...

  10. SQLSERVER EXISTS IN 优化

    数据量: 首先我们看看待优化的SQL: 简单的分析下来发现: EXISTS 这部分执行比较慢,我们来看一下, 这种写法比较便于理解,但是执行起来却很慢.既然这里慢,我们就要优化这部分. 首先我是想把拼 ...