2010-12-22 22:31:33 +00:00
|
|
|
[/
|
|
|
|
Copyright 2010 Neil Groves
|
|
|
|
Distributed under the Boost Software License, Version 1.0.
|
|
|
|
(See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
/]
|
2010-03-28 16:08:35 +00:00
|
|
|
[section:strided strided]
|
|
|
|
|
|
|
|
[table
|
|
|
|
[[Syntax] [Code]]
|
|
|
|
[[Pipe] [`rng | boost::adaptors::strided(n)`]]
|
|
|
|
[[Function] [`boost::adaptors::stride(rng, n)`]]
|
|
|
|
]
|
|
|
|
|
2010-12-22 22:31:33 +00:00
|
|
|
* [*Precondition:] `0 <= n` and `boost::size(rng)` is a valid expression.
|
2010-03-28 16:08:35 +00:00
|
|
|
* [*Returns:] A new range based on `rng` where traversal is performed in steps of `n`.
|
2010-12-22 22:31:33 +00:00
|
|
|
* [*Range Category:] __single_pass_range__
|
|
|
|
* [*Returned Range Category:] The range category of `rng`.
|
2010-03-28 16:08:35 +00:00
|
|
|
|
|
|
|
[section:strided_example strided example]
|
|
|
|
``
|
|
|
|
#include <boost/range/adaptor/strided.hpp>
|
|
|
|
#include <boost/range/algorithm/copy.hpp>
|
|
|
|
#include <boost/assign.hpp>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <iostream>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
int main(int argc, const char* argv[])
|
|
|
|
{
|
|
|
|
using namespace boost::adaptors;
|
|
|
|
using namespace boost::assign;
|
|
|
|
|
|
|
|
std::vector<int> input;
|
|
|
|
input += 1,2,3,4,5,6,7,8,9,10;
|
|
|
|
|
|
|
|
boost::copy(
|
|
|
|
input | strided(2),
|
|
|
|
std::ostream_iterator<int>(std::cout, ","));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
``
|
|
|
|
[endsect]
|
|
|
|
|
|
|
|
This would produce the output:
|
|
|
|
``
|
|
|
|
1,3,5,7,9
|
|
|
|
``
|
|
|
|
[endsect]
|
|
|
|
|
|
|
|
|