黑马c++ STL常用算法 笔记(2) 查找算法

简介: 黑马c++ STL常用算法 笔记(2) 查找算法

1.  find //查找元素

2.  find_if //按条件查找元素

3.  adjacent_find //查找相邻重复元素

4.  binary_search //二分查找法

5.  count //统计元素个数

6.  count_if //按条件统计元素个数


1.  find //查找元素

// 常用查找算法:find
/*
功能描述:
查找指定元素,找到'返回'指定元素的'迭代器',找不到返回结束迭代器end()
函数原型:
find(iterator beg, iterator end, value);
// 按值查找元素,找到返回指定位置迭代器,找不到返回结束迭代器位置
// beg 开始迭代器
// end 结束迭代器
// value 查找的'元素'
*/
#include <bits/stdc++.h>
using namespace std;
// 查找内置数据类型
 
void test01()
{
  vector<int> v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  // 查找容器中是否有元素5
  vector<int>::iterator it = find(v.begin(), v.end(), 5);
  if (it == v.end())
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes," << (*it) << endl; // √ yes,5
  }
}
// 查找自定义数据类型
class person
{
public:
  person(string name, int age)
  {
    this->name = name;
    this->age = age;
  }
  string name;
  int age;
  // 重载=,让底层find知道如何对比person数据类型
  bool operator==(const person &p)
  {
    if (this->name == p.name && this->age == p.age)
      return true;
    else
    {
      return false;
    }
  }
};
void test02()
{
  vector<person> v;
  person p1("aaa", 10);
  person p2("bbb", 20);
  person p3("ccc", 30);
  person p4("ddd", 40);
  v.push_back(p1);
  v.push_back(p2);
  v.push_back(p3);
  v.push_back(p4);
  vector<person>::iterator it = find(v.begin(), v.end(), p2);
  if (it == v.end())
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes," << (*it).name << " " << (*it).age << endl; // √ yes,bbb 20
  }
}
int main()
{
  test01();
  test02();
}
/*
总结:
利用find可以在容器中找指定的元素,返回值是迭代器
*/


2.  find_if //按条件查找元素

// 常用查找算法:find_if
/*
功能描述:
按条件查找元素
函数原型:
find_if(iterator beg, iterator end, _Pred);
// 按值查找元素,找到返回指定位置迭代器,找不到返回结束迭代器位置
// beg 开始迭代器
// end 结束迭代器
// _Pred 函数或者谓词(返回bool类型的仿函数)
*/
#include <bits/stdc++.h>
using namespace std;
// 查找内置数据类型
class greaterfive
{
public:
  bool operator()(int val)
  {
    return val > 5;
  }
};
void test01()
{
  vector<int> v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  // 查找容器中>5元素的位置
  vector<int>::iterator it = find_if(v.begin(), v.end(), greaterfive());
  if (it == v.end())
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes,大于5的数字为" << (*it) << endl; // √ yes,大于5的数字为6
  }
}
 
// 查找自定义数据类型
class person
{
public:
  person(string name, int age)
  {
    this->name = name;
    this->age = age;
  }
  string name;
  int age;
};
class greater20
{
public:
  bool operator()(person &p)
  {
    return p.age > 20;
  }
};
void test02()
{
  vector<person> v;
  person p1("aaa", 10);
  person p2("bbb", 20);
  person p3("ccc", 30);
  person p4("ddd", 40);
  v.push_back(p1);
  v.push_back(p2);
  v.push_back(p3);
  v.push_back(p4);
  // 找年龄>20的人
  vector<person>::iterator it = find_if(v.begin(), v.end(), greater20());
  if (it == v.end())
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes," << (*it).name << " " << (*it).age << endl; // √ yes,ccc 30
  }
}
int main()
{
  test01();
  test02();
}
/*
总结:
find_if按条件查找使查找更加灵活,提供的仿函数可以改变不同的策略
*/


3.  adjacent_find //查找相邻重复元素

// 常用查找算法:adjacent_find
/*
功能描述:
查找相邻重复元素
函数原型:
adjacent_find(iterator beg, iterator end);
// 查找'相邻重复'元素,返回相邻元素的第一个位置的迭代器
// beg 开始迭代器
// end 结束迭代器
*/
#include <bits/stdc++.h>
using namespace std;
void test01()
{
  vector<int> v;
 
  v.push_back(0);
  v.push_back(2);
  v.push_back(0);
  v.push_back(3);
  v.push_back(1);
  v.push_back(4);
  v.push_back(3);
  v.push_back(3);
  // 查找容器中'相邻重复'元素,返回相邻元素的第一个位置的迭代器
  vector<int>::iterator it = adjacent_find(v.begin(), v.end());
  if (it == v.end())
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes,第一个相邻重复元素为" << (*it) << endl; // √ yes,第一个相邻重复元素为3
  }
}
int main()
{
  test01();
}
/*
总结:
面试题中如果出现查找相邻重复元素,记得用STL中的adjacent_find算法
*/


4.  binary_search //二分查找法

// 常用查找算法:binary_search
// 二分查找法(返回bool,在有序序列中使用)
/*
功能描述:
查找指定元素是否'存在'
函数原型:
bool binary_search(iterator beg, iterator end, value);
// 查找指定的元素,查到 返回true 否则false
// 注意: '在无序序列中不可用'
// beg 开始迭代器
// end 结束迭代器
// value 查找的元素
*/
#include <bits/stdc++.h>
using namespace std;
void test01()
{
  vector<int> v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  // 查找元素,返回bool 容器必须为有序序列,若无序,则可能不会找到
  bool it = binary_search(v.begin(), v.end(), 9);
  if (!it)
  {
    cout << "no" << endl;
  }
  else
  {
    cout << "yes" << endl; // √ yes
  }
}
int main()
{
  test01();
}
/*
总结:
二分查找法查找效率很高,值得注意的是查找的容器中元素必须的有序序列
*/


5.  count //统计元素个数

// 常用查找算法:count
/*
功能描述:
统计元素个数(返回int)
函数原型:
count(iterator beg, iterator end, value);
// 统计元素出现次数
// beg 开始迭代器
// end 结束迭代器
// value 统计的元素
*/
#include <bits/stdc++.h>
using namespace std;
// 统计内置数据类型
void test01()
{
  vector<int> v;
  v.push_back(10);
  v.push_back(40);
  v.push_back(30);
  v.push_back(40);
  v.push_back(20);
  v.push_back(40);
  int num = count(v.begin(), v.end(), 40);
  cout << num << endl; // 3
}
// 统计自定义数据类型
class person
{
public:
  person(string name, int age)
  {
    this->name = name;
    this->age = age;
  }
  string name;
  int age;
  bool operator==(const person &p) // 一定要加const!!!!
  {
    if (this->age == p.age)
      return true;
    else
      return false;
  }
};
void test02()
{
  vector<person> v;
  person p1("aaa", 10);
  person p2("bbb", 10);
  person p3("ccc", 20);
  person p4("ddd", 40);
  v.push_back(p1);
  v.push_back(p2);
  v.push_back(p3);
  v.push_back(p4);
  person p("eee", 10);
  int num = count(v.begin(), v.end(), p); // 统计与eee年龄相同的个数
  cout << num << endl;                    // 2
}
int main()
{
  test02();
}
/*
总结:
统计自定义数据类型时候,需要配合重载 operator== 并且加const
*/


6.  count_if //按条件统计元素个数

// 常用查找算法:count_if
/*
功能描述:
按条件统计元素个数,返回int
函数原型:
count_if(iterator beg, iterator end, _Pred);
// 按条件统计元素出现次数
// beg 开始迭代器
// end 结束迭代器
// _Pred 谓词
*/
#include <bits/stdc++.h>
using namespace std;
// 统计内置数据类型
class greater20
{
public:
  bool operator()(int val)
  {
    return val > 20;
  }
};
void test01()
{
  vector<int> v;
  v.push_back(10);
  v.push_back(40);
  v.push_back(30);
  v.push_back(20);
  v.push_back(40);
  v.push_back(20);
  // 查>20的数
  int num = count_if(v.begin(), v.end(), greater20());
  cout << num << endl; // 3
}
// 统计自定义数据类型
class person
{
public:
  person(string name, int age)
  {
    this->name = name;
    this->age = age;
  }
  string name;
  int age;
};
class greater30
{
public:
  bool operator()(const person &p) // 加const!!!
  {
    if (p.age > 30)
      return true;
    else
      return false;
  }
};
void test02()
{
  vector<person> v;
  person p1("aaa", 10);
  person p2("bbb", 10);
  person p3("ccc", 20);
  person p4("ddd", 40);
  v.push_back(p1);
  v.push_back(p2);
  v.push_back(p3);
  v.push_back(p4);
  int num = count_if(v.begin(), v.end(), greater30()); // 统计>30的人数
  cout << num << endl;                                 // 1
}
int main()
{
  test01();
  test02();
}
/*
总结:
按值统计用count,按条件统计用count_if
*/


相关文章
|
存储 监控 算法
基于 C++ 哈希表算法实现局域网监控电脑屏幕的数据加速机制研究
企业网络安全与办公管理需求日益复杂的学术语境下,局域网监控电脑屏幕作为保障信息安全、规范员工操作的重要手段,已然成为网络安全领域的关键研究对象。其作用类似网络空间中的 “电子眼”,实时捕获每台电脑屏幕上的操作动态。然而,面对海量监控数据,实现高效数据存储与快速检索,已成为提升监控系统性能的核心挑战。本文聚焦于 C++ 语言中的哈希表算法,深入探究其如何成为局域网监控电脑屏幕数据处理的 “加速引擎”,并通过详尽的代码示例,展现其强大功能与应用价值。
252 2
|
存储 算法 C++
Windows共享文件:探秘C++实现的B树索引算法奇境
在数字化时代,Windows共享文件的高效管理至关重要。B树算法以其自平衡多路搜索特性,在文件索引与存储优化中表现出色。本文探讨B树在Windows共享文件中的应用,通过C++实现具体代码,展示其构建文件索引、优化数据存储的能力,提升文件检索效率。B树通过减少磁盘I/O操作,确保查询高效,为企业和个人提供流畅的文件共享体验。
|
监控 算法 数据处理
基于 C++ 的 KD 树算法在监控局域网屏幕中的理论剖析与工程实践研究
本文探讨了KD树在局域网屏幕监控中的应用,通过C++实现其构建与查询功能,显著提升多维数据处理效率。KD树作为一种二叉空间划分结构,适用于屏幕图像特征匹配、异常画面检测及数据压缩传输优化等场景。相比传统方法,基于KD树的方案检索效率提升2-3个数量级,但高维数据退化和动态更新等问题仍需进一步研究。未来可通过融合其他数据结构、引入深度学习及开发增量式更新算法等方式优化性能。
309 17
|
12月前
|
存储 机器学习/深度学习 算法
基于 C++ 的局域网访问控制列表(ACL)实现及局域网限制上网软件算法研究
本文探讨局域网限制上网软件中访问控制列表(ACL)的应用,分析其通过规则匹配管理网络资源访问的核心机制。基于C++实现ACL算法原型,展示其灵活性与安全性。文中强调ACL在企业与教育场景下的重要作用,并提出性能优化及结合机器学习等未来研究方向。
298 4
|
11月前
|
存储 监控 算法
基于跳表数据结构的企业局域网监控异常连接实时检测 C++ 算法研究
跳表(Skip List)是一种基于概率的数据结构,适用于企业局域网监控中海量连接记录的高效处理。其通过多层索引机制实现快速查找、插入和删除操作,时间复杂度为 $O(\log n)$,优于链表和平衡树。跳表在异常连接识别、黑名单管理和历史记录溯源等场景中表现出色,具备实现简单、支持范围查询等优势,是企业网络监控中动态数据管理的理想选择。
273 0
|
机器学习/深度学习 存储 算法
基于 C++ 布隆过滤器算法的局域网上网行为控制:URL 访问过滤的高效实现研究
本文探讨了一种基于布隆过滤器的局域网上网行为控制方法,旨在解决传统黑白名单机制在处理海量URL数据时存储与查询效率低的问题。通过C++实现URL访问过滤功能,实验表明该方法可将内存占用降至传统方案的八分之一,查询速度提升约40%,假阳性率可控。研究为优化企业网络管理提供了新思路,并提出结合机器学习、改进哈希函数及分布式协同等未来优化方向。
336 0
|
8月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
730 0
|
8月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
451 2
|
9月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
375 3
|
8月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
351 8