C++中std::distance使用方法示例

 更新时间:2025年04月07日 11:53:32   作者:点云SLAM  
std::distance 是 C++ 标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具有一定的参考价值,感兴趣的可以了解一下

std::distance 是 C++ 标准库中的一个函数,用于计算两个迭代器之间的距离,即从一个迭代器到另一个迭代器的元素个数。它可以用于各种容器的迭代器(如 std::vectorstd::list 等)。

语法

#include <iterator>

std::distance(iterator1, iterator2);

参数

  • iterator1:起始迭代器。
  • iterator2:结束迭代器。

返回值

  • 返回 iterator1 和 iterator2 之间的元素个数(即它们之间的距离)。

使用方式

以下是一个简单的示例,演示如何使用 std::distance

#include <iostream>
#include <vector>
#include <iterator>  // std::distance

int main() {
    std::vector<int> vec = {10, 20, 30, 40, 50};

    // 获取两个迭代器之间的距离
    auto it1 = vec.begin();
    auto it2 = vec.end();

    // 计算从 it1 到 it2 的距离
    std::cout << "Distance between it1 and it2: " << std::distance(it1, it2) << std::endl;

    // 获取元素的索引位置
    auto it3 = vec.begin() + 2;  // 指向第三个元素
    std::cout << "Distance from begin to it3: " << std::distance(it1, it3) << std::endl;

    return 0;
}

解释

  • std::distance(it1, it2):返回 it1 到 it2 之间的元素个数。
  • it1 是指向容器 vec 开始位置的迭代器,it2 是指向容器 vec 结束位置的迭代器(即 vec.end())。
  • 返回值是 5,表示 it1 到 it2 之间有 5 个元素。

示例输出:

Distance between it1 and it2: 5
Distance from begin to it3: 2

其他说明:

时间复杂度std::distance 的时间复杂度与容器类型有关。如果是随机访问迭代器(如 std::vector),时间复杂度为 O(1)。如果是双向或前向迭代器(如 std::list),时间复杂度为 O(n),其中 n 是两个迭代器之间的元素个数。

注意:对于非随机访问的容器(如 std::list 或 std::set),std::distance 可能会涉及到迭代器的逐个遍历,因此效率较低。

总结

std::distance 是一个用于计算两个迭代器之间元素个数的函数,常用于获取容器中两个元素之间的索引位置或计算偏移量。

到此这篇关于C++中std::distance使用方法示例的文章就介绍到这了,更多相关C++ std::distance内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅析C++ atomic 和 memory ordering

    浅析C++ atomic 和 memory ordering

    这篇文章主要介绍了C++ atomic 和 memory ordering的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • C/C++ 函数的存储位置和占用空间详解

    C/C++ 函数的存储位置和占用空间详解

    Lambda函数的代码部分在代码段中,被捕获的变量存储在Lambda函数对象的内部,这些变量的存储位置取决于Lambda函数对象的存储位置,这篇文章主要介绍了C/C++函数的存储位置和占用空间,需要的朋友可以参考下
    2023-06-06
  • c++函数指针和回调函数示例

    c++函数指针和回调函数示例

    这篇文章主要介绍了c++函数指针和回调函数示例,需要的朋友可以参考下
    2014-05-05
  • 浅谈使用C++多级指针存储海量qq号和密码

    浅谈使用C++多级指针存储海量qq号和密码

    这篇文章主要介绍了浅谈使用C++多级指针存储海量qq号和密码,分享了相关实例代码,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • C++基于CMD命令行实现扫雷小游戏

    C++基于CMD命令行实现扫雷小游戏

    这篇文章主要为大家详细介绍了C++基于CMD命令行实现扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C语言与C++动态通讯录超详细实现流程

    C语言与C++动态通讯录超详细实现流程

    这篇文章主要为大家介绍了C语言与C++动态实现通讯录,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-05-05
  • c语言中全局变量的设置方式

    c语言中全局变量的设置方式

    这篇文章主要介绍了c语言中全局变量的设置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • C++ STL标准库之std::list使用介绍及用法详解

    C++ STL标准库之std::list使用介绍及用法详解

    std::list是支持常数时间从容器任何位置插入和移除元素的容器,下面这篇文章主要给大家介绍了关于C++ STL标准库之std::list使用介绍及用法详解的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • C++中Qt的安装与配置步骤详解

    C++中Qt的安装与配置步骤详解

    Qt是一种C++编程框架,用于构建图形用户界面(GUI)应用程序和嵌入式系统,无论是初学者还是经验丰富的开发者,Qt都为构建高质量、可维护的应用程序提供了丰富的工具和支持,本文主要给大家介绍了C++中Qt的安装与配置步骤,需要的朋友可以参考下
    2023-12-12
  • C++学习之命名空间详解

    C++学习之命名空间详解

    C++中,命名空间(namespace)是一个重要的概念。命名空间可以为函数、变量、类等定义作用域,避免与其他定义的名称发生冲突。下面我们就来了解一下如何使用C++命名空间,以及一些常见的操作吧
    2023-04-04

最新评论