IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 常用容器查找函数find()使用小结(C++) -> 正文阅读

[C++知识库]常用容器查找函数find()使用小结(C++)

关于查找类函数

顺序查找类

find(first, last, type) //找值

find_if(first, last, function) //找符合function()

下面两个可以理解是字符串匹配

find_end(first1, last1, first2, last2) //在1中找2最后出现的位置

find_first_of(first1, last1, first2, last2) //在1中找2首次出现的位置

二分查找类

要求容器是顺序存储
mapset 本身就是顺序的
vectorstring 需要提前排序

lower_bound 第一个 num 的数值 返回迭代器

upper_bound 第一个 num > 的数值 返回迭代器

binary_search 单纯的二分查找 返回bool

常用容器find()使用举例

vector

void findVector()
{
    //本身并没有find
    //通过#include<algorithm>实现
    vector<int>arr = {1,68,515,48,5,5,8,4,48,1,2};
    auto it = find(arr.begin(), arr.end(), 5);
    if (it != arr.end())
        cout << *it << endl;
    else
        cout << "没找到" << endl;

    //普通数组的用法相同
    int arr2[] = {1,68,515,48,5,5,8,4,48,1,2};
    int n = sizeof(arr2)/sizeof(arr2[0]);
    auto it2 = find(arr2, arr2+n, 100);
    if (it2 != arr2+n)
        cout << *it2 << endl;
    else
        cout << "没找到" << endl;

    return ;
}

本代码输出:
=我是分割线=
5
没找到
=我是分割线=

string

void findString()
{
    string s = "Hello World!";
    //find的返回值是下标,找不到返回-1
    int pos;

    //默认从头开始找
    pos = s.find('l');
    //输出:2  即第一个'l'是在下标2的位置
    if (pos != -1)
        cout << pos << endl;
    else
        cout << "没找到" << endl;

    //从下标5的位置开始找,包含下标5
    pos = s.find('l', 5);
    //输出:9
    if (pos != -1)
        cout << pos << endl;
    else
        cout << "没找到" << endl;

    //寻找字串也是同样的用法
    pos = s.find("ll");
    //pos = s.find("ll", 3);
    if (pos != -1)
        cout << pos << endl;
    else
        cout << "没找到" << endl;

    return ;
}

本代码输出:
=我是分割线=
2
9
2
=我是分割线=

stack和queue和priority_queue

没有迭代器

deque

void findDeque()
{
    vector<int>arr = {1,68,515,48,5,5,8,4,48,1,2};
    deque<int>dq(arr.begin(), arr.end());

    auto it = find(dq.begin(), dq.end(), 66);
    if (it != dq.end())
        cout << *it << endl;
    else
        cout << "没找到" << endl;

    return ;
}

本代码输出:
=我是分割线=
没找到
=我是分割线=

list

void findList()
{
    vector<int>arr = {1,68,515,48,5,5,8,4,48,1,2};
    list<int>lst(arr.begin(), arr.end());

    auto it = find(lst.begin(), lst.end(), 66);
    if (it != lst.end())
        cout << *it << endl;
    else
        cout << "没找到" << endl;

    return ;
}

本代码输出:
=我是分割线=
没找到
=我是分割线=

set

void findSet()
{

    vector<int>arr = {1,68,515,48,5,5,8,4,48,1,2};
//   unordered_set
//   multiset
//   unordered_multiset
    set<int>st(arr.begin(), arr.end());

    auto it = st.find(8);
    if (it != st.end())
        cout << *it << endl;
    else
        cout << "没找到" << endl;

    return ;
}

本代码输出:
=我是分割线=
8
=我是分割线=

map

void findMap()
{
    vector<int>arr = {1,68,515,48,5,5,8,4,48,1,2};
//   unordered_map
//   multimap
//   unordered_multimap
    map<int, int>mp;
    for (int i = 0; i < arr.size(); i++){
        pair<int, int>pir(arr[i], i);
        mp.insert(pir);
    }

    auto it = mp.find(8);
    if (it != mp.end())
        printf("mp[%d] = %d\n", it->first, it->second);
    else
        puts("没找到");

    return ;
}

本代码输出:
=我是分割线=
mp[8] = 6
=我是分割线=

关于map中通过value找可以可以使用find_if()来实现,具体代码请看下面链接
C++ map 根据value找key

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-24 11:15:53  更:2021-07-24 11:16:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/8 11:04:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码