C++ search()函数用法详解(深入了解,一文学会)

find_end() 函数用于在序列 A 中查找序列 B 最后一次出现的位置。那么,如果想知道序列 B 在序列 A 中第一次出现的位置,该如何实现呢?可以借助 search() 函数。

search() 函数定义在<algorithm>头文件中,其功能恰好和 find_end() 函数相反,用于在序列 A 中查找序列 B 第一次出现的位置。

本文作者原创,转载请附上文章出处与本文链接。

C++ search()函数用法详解(深入了解,一文学会)目录

1 search()语法格式

2 search() 示例

2.1 第一种语法格式

2.2 第二种语法格式        第二种语法自定义规则,不做介绍因为感觉有点鸡肋。


1 search()语法格式

        和 find_end() 相同,search() 函数也提供有以下 2 种语法格式:

//查找 [first1, last1) 范围内第一个 [first2, last2) 子序列
ForwardIterator search (ForwardIterator first1, ForwardIterator last1,
                        ForwardIterator first2, ForwardIterator last2);
//查找 [first1, last1) 范围内,和 [first2, last2) 序列满足 pred 规则的第一个子序列
ForwardIterator search (ForwardIterator first1, ForwardIterator last1,
                        ForwardIterator first2, ForwardIterator last2,
                        BinaryPredicate pred);

其中,各个参数的含义分别为:

  • first1、last1:都为正向迭代器,其组合 [first1, last1) 用于指定查找范围(也就是上面例子中的序列 A);
  • first2、last2:都为正向迭代器,其组合 [first2, last2) 用于指定要查找的序列(也就是上面例子中的序列 B);
  • pred:用于自定义查找规则。该规则实际上是一个包含 2 个参数且返回值类型为 bool 的函数(第一个参数接收 [first1, last1) 范围内的元素,第二个参数接收 [first2, last2) 范围内的元素)。函数定义的形式可以是普通函数,也可以是函数对象。

实际上,第一种语法格式也可以看做是包含一个默认的 pred 参数,该参数指定的是一种相等规则,即在 [first1, last1) 范围内查找和 [first2, last2) 中各个元素对应相等的子序列;而借助第二种语法格式,我们可以自定义一个当前场景需要的匹配规则。

同时,search() 函数会返回一个正向迭代器,当函数查找成功时,该迭代器指向查找到的子序列中的第一个元素;反之,如果查找失败,则该迭代器的指向和 last1 迭代器相同。

2 search() 示例

#include <iostream>     // std::cout
#include <algorithm>    // std::search
#include <vector>       // std::vector
using namespace std;


//以普通函数的形式定义一个匹配规则
bool mycomp1(int i, int j) {
    return (i % j == 0);
}


//以函数对象的形式定义一个匹配规则
class mycomp2 {
public:
    bool operator()(const int& i, const int& j) {
        return (i % j == 0);
    }
};


int main() {
    vector<int> myvector{ 1,2,3,4,8,12,18,12,18,1,2,3 };
    int myarr[] = { 12,18,1 };
    
    //调用第一种语法格式
    vector<int>::iterator it = search(myvector.begin(), myvector.end(), myarr, myarr+3);
    if (it != myvector.end()) {
        cout << "第一个{12,18,1}的起始位置为:" << it - myvector.begin() << "  ,*it = " << *it << endl;
    }


    int myarr2[] = { 18,1,2 };
    //调用第二种语法格式
    it = search(myvector.begin(), myvector.end(), myarr2, myarr2 + 3, mycomp2());
    if (it != myvector.end()) {
        cout << "第一个{18,1,2}的起始位置为:" << it - myvector.begin() << "  ,*it = " << *it;
    }
    return 0;
}

2.1 第一种语法格式

下面有两个示例:

示例1: 通过程序的执行结果可以看到,search() 函数找到了 myvector 容器中第一个 {1,2,6},起始位置下标为9,可以通过 myvector容器下标9、10、11来找到对应的1,2,6。

示例2:  通过程序的执行结果可以看到,search() 函数找到了 myvector 容器中第一个 {11,1,2},起始位置下标为8,可以通过 myvector容器下标8、9、10来找到对应的11,1,2。

示例3:如果未找到则不进行返回

#include <iostream>     // std::cout
#include <algorithm>    // std::search
#include <vector>       // std::vector
using namespace std;

int main() {
    vector<int> myvector{ 1,2,3,4,8,12,18,12,18,1,2,6 };
    int myarr[] = { 1,2,6 };
    
    //调用第一种语法格式
    vector<int>::iterator it = search(myvector.begin(), myvector.end(), myarr, myarr+3);
    if (it != myvector.end()) {
        cout << "第一个{1,2,6}的起始位置为:" << it - myvector.begin() << "  ,*it = " << *it << endl;
    }

    return 0;
}

#include <iostream>     // std::cout
#include <algorithm>    // std::search
#include <vector>       // std::vector
using namespace std;

int main() {
    vector<int> myvector{ 1,2,3,4,8,12,18,12,11,1,2,6 };
    int myarr[] = { 11,1,2 };
    
    //调用第一种语法格式
    vector<int>::iterator it = search(myvector.begin(), myvector.end(), myarr, myarr+3);
    if (it != myvector.end()) {
        cout << "第一个{11,1,2}的起始位置为:" << it - myvector.begin() << "  ,*it = " << *it << endl;
    }

    return 0;
}

    //不返回值
    int myarr[] = { 1,2,100 };
    
    //调用第一种语法格式
    vector<int>::iterator it = search(myvector.begin(), myvector.end(), myarr, myarr + 3);
    if (it != myvector.end()) {
        cout << "第一个{11,1,2}的起始位置为:" << it - myvector.begin() << "  ,*it = " << *it << endl;
    }
    

2.2 第二种语法格式
        第二种语法自定义规则,不做介绍因为感觉有点鸡肋。

  • 8
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
merge函数C++标准库中的一个函数,用于合并两个有序序列。在使用merge函数之前,需要确保两个序列是有序的。可以通过以下两种方式来使用merge函数: 1. 使用容器的merge函数: 使用容器的merge函数可以直接将两个有序容器合并成一个有序容器。例如,可以使用list容器的merge函数来合并两个有序链表。在调用merge函数之前,需要确保链表是有序的。可以通过在调用merge函数之前对链表进行排序来实现。例如,在调用L1.merge(L2)之前,可以添加以下两行代码来对链表进行排序:L1.sort(); L2.sort();然后,调用merge函数将L2合并到L1中。最后,可以使用迭代器遍历输出合并后的有序链表。 2. 使用算法库的merge函数: 使用算法库的merge函数可以将两个有序数组合并成一个有序数组。在调用merge函数之前,需要确保数组是有序的。可以通过在调用merge函数之前对数组进行排序来实现。例如,可以使用vector容器和算法库的merge函数来合并两个有序数组。首先,创建一个新的vector容器来存储合并后的有序序列。然后,调用merge函数将两个有序数组合并到新的vector容器中。最后,可以使用迭代器遍历输出合并后的有序序列。 总结起来,merge函数可以用于合并两个有序序列,无论是使用容器的merge函数还是算法库的merge函数,都需要确保两个序列是有序的。 #### 引用[.reference_title] - *1* [C++ merge函数](https://blog.csdn.net/DannyYo_SCAU/article/details/84683781)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [C++ merge()和inplace_merge()函数用法详解(深入了解,一文学)](https://blog.csdn.net/qq_37529913/article/details/123215469)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

双子座断点

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值