How to replicate map, filter and reduce behaviors in C++ using STL?

后端 未结 2 1693
野性不改
野性不改 2021-01-31 10:27

I suppose we can use std::transform to replicate the map behavior in C++ like this :

std::vector in = { 1 , 2 , 3 ,4 }; 
std::vector out(i         


        
2条回答
  •  北荒
    北荒 (楼主)
    2021-01-31 11:07

    You can use std::transform to do mapping, and std::copy_if for filtering.

    You have two options for reduce depending on your input and if you want to use a specific type of execution model. I've written some simple examples below to demonstrate common use cases. Note that there are multiple overloads for all these algorithms that you should use depending on your needs.


    1. std::transform

    Squaring a vector of integers in place:

    std::vector nums{1,2,3,4};
    auto unary_op = [](int num) {return std::pow(num, 2);};
    std::transform(nums.begin(), nums.end(), nums.begin(), unary_op);
    // nums: 1, 4, 9, 16
    
    1. std::copy_if

    Filtering odd numbers only from a vector of integers:

    std::vector nums{1,2,3,4};
    std::vector odd_nums;
    auto pred = [](int num) {return num & 1;};
    std::copy_if(nums.begin(), nums.end(), std::back_inserter(odd_nums), pred);
    // odd_nums: 1, 3
    
    1. std::reduce

    Sum of integers in the vector starting from 0 using parallel execution model. This is really useful if, for example, you are doing a reduce operation on a really big list. Reckon that the binary operator in this case ("+") is associate and commutative, otherwise the behavior would've been non-deterministic. This is really important. The reduce operation is out-of-order if the execution model is not sequential. Only available since C++17.

    std::vector nums{1,2,3,4};
    auto binary_op = [](int num1, int num2){return num1 + num2;};
    int result = std::reduce(std::execution::par, nums.begin(), nums.end(), 0, binary_op);
    // result: 10
    
    1. std::accumulate

    Same as reduce except it doesn't support execution model and the reduce operation is done in-order.

    std::vector nums{1,2,3,4};
    auto binary_op = [](int num1, int num2){return num1 + num2;};
    int result = std::accumulate(nums.begin(), nums.end(), 0, binary_op);
    // result: 10
    

提交回复
热议问题