On this page
std::distance
Defined in header <iterator> |
||
|---|---|---|
|
(constexpr since C++17) |
Returns the number of hops from first to last.
If InputIt is not LegacyRandomAccessIterator, the behavior is undefined if last is not reachable from first.
If InputIt is LegacyRandomAccessIterator, the behavior is undefined if first and last are neither reachable from each other.
Parameters
| first | - | iterator pointing to the first element |
| last | - | iterator pointing to the end of the range |
| Type requirements | ||
-InputIt must meet the requirements of LegacyInputIterator. The operation is more efficient if InputIt additionally meets the requirements of LegacyRandomAccessIterator. |
||
Return value
The number of increments needed to go from first to last.
The value may be negative if random-access iterators are used and |
(since C++11) |
Complexity
Linear.
However, if InputIt additionally meets the requirements of LegacyRandomAccessIterator, complexity is constant.
Possible implementation
See also the implementations in libstdc++ and libc++.
| C++98 implementation via tag dispatch, with constexpr removed |
|---|
|
| C++17 implementation via if constexpr |
|
Example
#include <iostream>
#include <iterator>
#include <vector>
int main()
{
std::vector<int> v{3, 1, 4};
std::cout << "distance(first, last) = "
<< std::distance(v.begin(), v.end()) << '\n'
<< "distance(last, first) = "
<< std::distance(v.end(), v.begin()) << '\n';
// the behavior is undefined (until LWG940)
static constexpr auto il = {3, 1, 4};
// Since C++17 `distance` can be used in constexpr context.
static_assert(std::distance(il.begin(), il.end()) == 3);
static_assert(std::distance(il.end(), il.begin()) == -3);
}
Output:
distance(first, last) = 3
distance(last, first) = -3
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 940 | C++98 | the wording was unclear for the case where first is reachable from last |
made clear |
See also
| advances an iterator by given distance (function template) |
|
| returns the number of elements satisfying specific criteria (function template) |
|
|
(C++20)
|
returns the distance between an iterator and a sentinel, or between the beginning and end of a range (niebloid) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/iterator/distance