C++_STL_2021.11.12

手动实现STL中的search_n算法,代码如下:

 

#pragma once

#include <iostream>
#include <algorithm>
#include <string>
#include <vector>

using namespace std;


template<typename ForwardIter, typename Integer, typename T>
ForwardIter np_serach_n(
    ForwardIter first,
    ForwardIter last,
    Integer count,
    const T& value)
{
    if (count < 0)
        return first;


    first = find(first, last, value);
    while (first != last)
    {
        ForwardIter cur = first;

        cur++;
        int n = count - 1;

        while (cur != last && n != 0 && *cur == value)
        {
            cur++;
            n--;
        }

        if (n == 0)
            return first;
        else
            first = find(cur, last, value);
    }

    return last;
}

template<typename ForwardIter, typename Integer, typename T, typename BinaryPred>
ForwardIter np_serach_n(
    ForwardIter first,
    ForwardIter last,
    Integer count,
    const T& value,
    BinaryPred binary_pred)
{
    if (count < 0)
        return first;

    while (first != last && !binary_pred(*first, value))
        ++first;

    while (first != last)
    {
        ForwardIter cur = first;
        ++cur;

        Integer n = count - 1;

        while (cur != last && n != 0 && binary_pred(*cur, value)) {
            cur++;
            n--;
        }

        if (n == 0)
            return first;
        else
        {
            first = cur;
            while (first != last && !binary_pred(*first, value))
                ++first;
        }
    }

    return last;
}

 

 

调用方法:

 

// Neptune.cpp: 定义应用程序的入口点。
//

#include "Neptune.h"
#include "non_mutate.h"
#include <functional>

void test_np_search_n()
{
    int count = 2;
    string number = "world";

    vector<string> numbers{ "Hello", "world", "world", "I", "love", "you", "world" };

    auto it = np_serach_n<decltype(numbers.cbegin()), decltype(count), decltype(number)>(
        numbers.cbegin(), numbers.cend(), count, number);


    if (it != numbers.cend())
    {
        cout << "Find " << count << " " << number << " index is: " << it - numbers.cbegin();
    }
    else
    {
        cout << "Can't find " << count << " " << number;
    }

}


void test_np_serach_n_predicat(int count = 2)
{
    //int number = 4;
    //vector<int> data{ 1, 3, 4, 5, 2, 1, 7, 8, 9 };
    std::string number("hellooo");
    vector<decltype(number)> data {"hello", "world", "chris", "I", "love", "you"};

    
    std::function<bool(decltype(*data.cbegin()), decltype(number))>  Predicate;

    auto it = np_serach_n<decltype(data.cbegin()), decltype(count), decltype(number), decltype(Predicate)>(
        data.cbegin(),
        data.cend(),
        count,
        number,
        [](decltype(*data.cbegin()) a, decltype(number) b) -> bool {
            return b.length() - a.length() > 2;
        });

    if (it != data.cend())
    {
        cout << "Find " << count << " index is: " << it - data.cbegin();
    }
    else
    {
        cout << "Can't find! ";
    }
}

int main()
{
    test_np_search_n();
    test_np_serach_n_predicat();
    return 0;
}

 

posted @ 2021-11-12 16:25  绍荣  阅读(26)  评论(0编辑  收藏  举报