非常简单的问题:是否有一种智能方法可以使用STL从另一个向量的规则间隔元素创建子向量?
简而言之,是否可以使用STL算法编写以下代码:
int inc = 2;
std::vector<double> v_origin;
std::vector<double> v_dest;
for (int i = 0; i < v_origin.size(); i+= inc)
v_dest.push_back(v_origin[i]);
Run Code Online (Sandbox Code Playgroud)
就像我在Matlab或Python中写的那样:
v_dest = v_origin[0:inc:end];
Run Code Online (Sandbox Code Playgroud)
作为一般解决方案,您可以定义步幅迭代器.如果您使用Boost.Range,那么它已经作为strided范围适配器.
例:
#include <vector>
#include <iostream>
#include <boost/range/adaptors.hpp>
#include <boost/range/algorithm.hpp>
int main()
{
int inc = 2;
std::vector<double> v_origin;
std::vector<double> v_dest;
for (int i = 0; i < 10; ++ i)
v_origin.push_back(i);
boost::copy(v_origin | boost::adaptors::strided(2),
std::back_inserter(v_dest));
// ^ In Python: v_dest[] = v_origin[::2]
boost::copy(v_dest, std::ostream_iterator<double>(std::cout, ", "));
}
Run Code Online (Sandbox Code Playgroud)