std::ranges::adjacent_view<V,N>::iterator<Const>::operator[]
From cppreference.com
< cpp | ranges | adjacent view | iterator
C++
Ranges library
|
Range primitives | |||||||
|
Range concepts | |||||||||||||||||||
|
Range factories | |||||||||
|
Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
Helper items | |||||||||||||||||
|
std::ranges::adjacent_view
Member functions | ||||
Iterator | ||||
Member functions | ||||
adjacent_view::iterator::operator[] | ||||
Non-member functions | ||||
Sentinel | ||||
Member functions | ||||
Non-member functions | ||||
constexpr
auto operator[
]
( difference_type n )
const
requires ranges::random_access_range <Base> ; |
(since C++23) | |
Returns an element at specified relative location.
Let current_
be an underlying array of iterators.
Equivalent to:
return /*tuple-transform*/([&](auto& i) -> decltype(auto) { return i[n]; }, current_);
Parameters
n | - | position relative to current location |
Return value
The element at displacement n relative to the current location.
Example
Run this code
#include <ranges> #include <tuple> int main() { constexpr static auto v = {0, 1, 2, 3, 4, 5}; // └──┬──┘ // └─────────────────┐ constexpr auto view = v | std::views::adjacent<3>; // │ // ┌───────────────────┬──────────────┘ // │ ┌──┴──┐ static_assert(view[2] == std::tuple{2, 3, 4}); }