c – 从另一个向量的规则间隔元素创建子向量
发布时间:2020-12-16 09:38:57 所属栏目:百科 来源:网络整理
导读:非常简单的问题:是否有一种智能方法可以使用STL从另一个向量的规则间隔元素创建子向量? 简而言之,是否可以使用STL算法编写以下代码: int inc = 2;std::vectordouble v_origin;std::vectordouble v_dest;for (int i = 0; i v_origin.size(); i+= inc) v_de
非常简单的问题:是否有一种智能方法可以使用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]); 就像我在Matlab或Python中写的那样: v_dest = v_origin[0:inc:end]; 解决方法
作为一般解决方案,您可以定义一个
stride iterator.如果您使用Boost.Range,那么它已经作为
strided range adaptor.
例: #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,",")); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |