STL常用查找算法

简介: STL常用查找算法

全部案例链接


https://download.csdn.net/download/weixin_45525272/12536637



常用查找算法


find算法 查找元素


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value 查找的元素
@return 返回查找元素的位置


find(iterator beg, iterator end, value)


find_if算法 条件查找


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  callback 回调函数或者谓词(返回bool类型的函数对象)
@return bool 查找返回true 否则false


find_if(iterator beg, iterator end, _callback);


adjacent_find算法 查找相邻重复元素


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  _callback 回调函数或者谓词(返回bool类型的函数对象)
@return 返回相邻元素的第一个位置的迭代器


adjacent_find(iterator beg, iterator end, _callback);


binary_search算法 二分查找法


注意: 在无序序列中不可用
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value 查找的元素
@return bool 查找返回true 否则false


bool binary_search(iterator beg, iterator end, value);


count算法 统计元素出现次数


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  value回调函数或者谓词(返回bool类型的函数对象)
@return int返回元素个数


count(iterator beg, iterator end, value);


count_if算法 统计元素出现次数


@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  callback 回调函数或者谓词(返回bool类型的函数对象)
@return int返回元素个数


count_if(iterator beg, iterator end, _callback);


案例


#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <algorithm>
using namespace std;
#include <vector>
#include <string>
#include <functional>
/*
find算法 查找元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value 查找的元素
@return 返回查找元素的位置
*/
void test01()
{
  vector<int>v;
  for (int i = 0; i < 10;i++)
  {
    v.push_back(i);
  }
  vector<int>::iterator pos = find(v.begin(), v.end(), 5);
  if (pos!=v.end())
  {
    cout << "找到了数据:" << *pos << endl;
  }
  else
  {
    cout << "未找到" << endl;
  }
}
class Person
{
public:
  Person(string name, int age)
  {
    this->m_Name = name;
    this->m_Age = age;
  }
  bool operator==( const Person&p)
  {
    if (this->m_Name == p.m_Name && this->m_Age == p.m_Age)
    {
      return true;
    }
    return false;
  }
  string m_Name;
  int m_Age;
};
//利用find查找自定义数据类型
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 pos = find(v.begin(), v.end(), p2);
  if (pos != v.end())
  {
    cout << "找到了数据姓名:" << (*pos).m_Name << " 年龄:" << pos->m_Age << endl;
  }
  else
  {
    cout << "未找到" << endl;
  }
}
class MyCompare :public binary_function<Person*, Person* ,bool>
{
public:
  bool operator()( Person * p1 , Person * p2) const
  {
    if (p1->m_Name == p2->m_Name && p1->m_Age == p2->m_Age)
    {
      return true;
    }
    return false;
  }
};
void test03()
{
  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);
  Person * p = new Person("bbb", 20);
  vector<Person*>::iterator pos = find_if(v.begin(), v.end(),  bind2nd( MyCompare(), p));
  if (pos != v.end())
  {
    cout << "找到了数据姓名:" << (*pos)->m_Name << " 年龄:" << (*pos)->m_Age << endl;
  }
  else
  {
    cout << "未找到" << endl;
  }
}
/*
adjacent_find算法 查找相邻重复元素
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  _callback 回调函数或者谓词(返回bool类型的函数对象)
@return 返回相邻元素的第一个位置的迭代器
*/
void test04()
{
  vector<int>v;
  v.push_back(2);
  v.push_back(3);
  v.push_back(4);
  v.push_back(5);
  v.push_back(5);
  v.push_back(6);
  v.push_back(2);
  vector<int>::iterator pos = adjacent_find(v.begin(), v.end());
  if (pos!= v.end())
  {
    cout << "找到了相邻重复元素为: " << *pos << endl;
  }
  else
  {
    cout << "未找到" << endl;
  }
}
/*
binary_search算法 二分查找法
注意: 在无序序列中不可用
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param value 查找的元素
@return bool 查找返回true 否则false
*/
void test05()
{
  vector<int>v;
  for (int i = 0; i < 10;i++)
  {
    v.push_back(i);
  }
  bool ret =  binary_search(v.begin(), v.end(), 4);
  if (ret)
  {
    cout << "找到了4" << endl;
  }
  else
  {
    cout << "未找到" << endl;
  }
}
/*
/*
count算法 统计元素出现次数
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  value回调函数或者谓词(返回bool类型的函数对象)
@return int返回元素个数
*/
/*
count_if算法 统计元素出现次数
@param beg 容器开始迭代器
@param end 容器结束迭代器
@param  callback 回调函数或者谓词(返回bool类型的函数对象)
@return int返回元素个数
*/
class GreaterThenFour
{
public:
  bool operator()(int v)
  {
    return v >= 4;
  }
};
void test06()
{
  vector<int>v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  v.push_back(4);
  v.push_back(4);
  v.push_back(4);
  v.push_back(4);
  int num = count(v.begin(), v.end(), 4);
  cout << "4的个数为" << num << endl;
  num = count_if(v.begin(), v.end(), GreaterThenFour());
  cout << "大于等于 4的个数为" << num << endl;
}
int main(){
  //test01();
  //test02();
  //test03();
  //test04();
  //test05();
  test06();
  system("pause");
  return EXIT_SUCCESS;
}
相关文章
|
1月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
22 0
|
5月前
|
算法 前端开发 Linux
【常用技巧】C++ STL容器操作:6种常用场景算法
STL在Linux C++中使用的非常普遍,掌握并合适的使用各种容器至关重要!
89 10
|
4月前
|
算法 C++
STL算法大全
以上只是一部分STL算法的简单概述,每一个算法都有其特定的使用场景和规则,具体使用时需要参考相关文档或者教程进行深入理解和学习。
32 0
|
5月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
|
6月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(5) 常用算术生成算法
黑马c++ STL常用算法 笔记(5) 常用算术生成算法
|
6月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(4) 常用拷贝和替换算法
黑马c++ STL常用算法 笔记(4) 常用拷贝和替换算法
|
6月前
|
存储 算法 搜索推荐
黑马c++ STL常用算法 笔记(3) 排序算法
黑马c++ STL常用算法 笔记(3) 排序算法
|
6月前
|
算法 C++
黑马c++ STL常用算法 笔记(2) 查找算法
黑马c++ STL常用算法 笔记(2) 查找算法
|
6月前
|
算法 C++
c++算法学习笔记 (21) STL
c++算法学习笔记 (21) STL
|
6月前
|
算法 C++ 容器
黑马c++ STL常用算法 笔记(6) 常用集合算法
黑马c++ STL常用算法 笔记(6) 常用集合算法