std::advance std::distance std::next

1.std::advance

distance的函数声明如下:
	template< class InputIt >
	constexpr typename std::iterator_traits<InputIt>::difference_type 
  	distance( InputIt first, InputIt last );    

  Returns the number of elements between first and last.

distance是计算两个iterator间隔的距离,例子:
#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';
}
Output:
distance(first, last) = 3
distance(last, first) = -3

2.std::advance

template <class InputIterator, class Distance>
void advance (InputIterator& it, Distance n);

advance迭代器辅助函数。
使迭代器it偏移n,其中n为整数,n为正数向右偏移,n为负数向左偏移。
advance是改变iterator的指向,例子如下:
#include <iostream>
#include <iterator>
#include <vector>
 
int main() 
{
    std::vector<int> v{ 3, 1, 4 };
 
    auto vi = v.begin();
 
    std::advance(vi, 2);
 
    std::cout << *vi << '\n';
}
Output:
4

3.std::next

  C++  Iterator library  Defined in header <iterator>
声明如下:
template< class ForwardIt >
ForwardIt next(ForwardIt it, typename std::iterator_traits<ForwardIt>::difference_type n = 1 );
参数
it - 一个迭代器
n - 相对于前面迭代器的元素个数

返回值:返回相对it后第n个迭代器
函数的定义:
template<class ForwardIt>
	ForwardIt next(ForwardIt it, typename std::iterator_traits<ForwardIt>::difference_type n = 1)
	{
 	   std::advance(it, n);
	   return it;
	}
例子:
#include <iostream>
#include <iterator>
#include <vector>
int main() 
{
    std::vector<int> v{ 3, 1, 4 };
    auto it = v.begin();
    auto nx = std::next(it, 2);
    std::cout << *it << ' ' << *nx << '\n';
}
Output:
3 4
注意:当next中的n不给予赋值时,n默认值为1。
在++中,与迭代器密切相关的STL函数有很多。这些函数允许我们在容器中进行迭代和操作,提供了方便且高效的方法来处理容器中的元素。以下是一些与迭代器密切相关的常用std函数: 1. `std::begin` 和 `std::end`:这两个函数用于获取容器的起始迭代器和结束迭代器。例如,`std::begin(container)` 返回容器 `container` 的起始迭代器,`std::end(container)` 返回容器的结束迭代器。 2. `std::advance`:该函数用于将迭代器向前或向后移动指定的距离。例如,`std::advance(it, n)` 将迭代器 `it` 向前移动 `n` 个位置。 3. `std::distance`:该函数用于计算两个迭代器之间的距离。例如,`std::distance(first, last)` 返回从迭代器 `first` 到迭代器 `last` 之间的元素数量。 4. `std::next` 和 `std::prev`:这两个函数用于获取给定迭代器的下一个或上一个迭代器。例如,`std::next(it)` 返回 `it` 的下一个迭代器,`std::prev(it)` 返回 `it` 的上一个迭代器。 5. `std::advance` 和 `std::distance`:这两个函数通常结合使用,用于在迭代器范围内进行迭代。例如,`std::advance(first, n)` 可以将迭代器 `first` 向前移动 `n` 个位置,而 `std::distance(first, last)` 可以计算从迭代器 `first` 到迭代器 `last` 之间的元素数量。 6. `std::copy`:该函数用于将一个容器的元素复制到另一个容器中。它接受两个迭代器参数,表示源容器中要复制的范围,以及目标容器的起始位置。 7. `std::find`:该函数用于在容器中查找指定的值,并返回找到的第一个匹配元素的迭代器。 8. `std::sort`:该函数用于对容器中的元素进行排序。它接受两个迭代器参数,表示排序的范围。 9. `std::reverse`:该函数用于反转容器中元素的顺序。它接受两个迭代器参数,表示反转操作的范围。 这些只是一些常用的与迭代器密切相关的std函数,STL还提供了更多用于处理容器的函数和算法。使用这些函数,我们可以方便地遍历、操作和处理容器中的元素,提高代码的效率和可读性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值