迭代器iterator是C++中用于遍历容器中元素的对象

C++中的迭代器是一种对象,用于在容器中遍历元素。它提供了一种抽象的方式来访问容器中的元素,而不暴露底层数据结构的细节。通过迭代器,可以遍历顺序容器(如vector、list、deque等)、关联容器(如map、set等)以及其他容器类型(如数组等)中的元素。

在C++中,迭代器通常是类似指针的对象,可以通过解引用操作符*来访问其指向的元素,也可以通过递增操作符++来移动到容器中的下一个元素。

迭代器通常提供以下操作:

  1. 解引用操作:*it用于获取迭代器指向的元素。
  2. 递增操作:++it用于将迭代器移动到容器中的下一个元素。

迭代器的种类根据所操作的容器类型而有所不同。例如,对于顺序容器,迭代器是随机访问的,可以进行+-运算来快速定位元素;而对于关联容器,迭代器是双向的,只能进行单步移动,不能进行随机访问。

在使用迭代器时,需要注意迭代器的有效性,避免在容器中添加或删除元素时使迭代器失效。通常在循环中使用迭代器遍历容器时,会在每次循环迭代之前检查迭代器是否已经达到容器的末尾,以避免越界访问。

下面是一个简单的示例,演示了如何使用迭代器遍历vector容器中的元素:
​​​​​​​迭代器的使用通常伴随着容器的.begin()和.end()成员函数,这两个函数分别返回指向容器第一个元素和尾后元素的迭代器。这样,通过迭代器,我们可以遍历容器的所有元素,例如:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec = {1, 2, 3, 4, 5};

    // 使用迭代器遍历vector中的元素
    for (auto it = vec.begin(); it != vec.end(); ++it) {
        std::cout << *it << " ";
    }
    std::cout << std::endl;

    return 0;
}

在这个示例中,我们使用了vec.begin()vec.end()获取vector的起始和结束迭代器,并在循环中使用迭代器it来遍历vector中的元素,并通*it来访问元素的值

-

#include <iostream>
#include <map>

int main() {
    std::map<std::string, int> myMap = {
        {"apple", 5},
        {"banana", 3},
        {"orange", 7}
    };

    // 查找键为"apple"的元素
    auto it = myMap.find("apple");

    // 如果找到了,则输出对应的值
    if (it != myMap.end()) {
        std::cout << "Value of apple: " << it->second << std::endl;
    } else {
        std::cout << "Key 'apple' not found!" << std::endl;
    }

    return 0;
}

在上下文中,it是一个迭代器变量,用于指向std::map中的元素。it是通过find方法找到的一个迭代器,指向std::map中指定键的元素(如果找到的话)。通常,我们会检查迭代器是否等于end()方法返回的迭代器,来确定是否找到了元素。

-

#include <iostream>
#include <set>

int main() {
    std::set<int> mySet = {1, 2, 3, 4, 5};
    
    mySet.insert(6);
    mySet.erase(3);
    
    auto it = mySet.find(2);
    if (it != mySet.end()) {
        std::cout << "Found element: " << *it << std::endl;
    }
    
    return 0;
}

 -

以下是对C++中常见容器的简要总结:

1. **Array(数组)**:
   - 固定大小的容器,存储相同类型的元素。
   - 元素在内存中是连续存储的。
   - 访问元素的时间复杂度为 O(1)。
   - 大小在编译时确定,无法动态改变。

2. **Vector(向量)**:
   - 动态数组,大小可动态增长。
   - 元素在内存中是连续存储的。
   - 支持随机访问,时间复杂度为 O(1)。
   - 插入和删除操作可能导致内存重新分配,时间复杂度为 O(n)。

3. **List(链表)**:
   - 双向链表,可以快速在任意位置插入和删除元素。
   - 元素在内存中不一定是连续存储的。
   - 不支持随机访问,需要遍历链表才能访问元素。

4. **Queue(队列)**:
   - 先进先出(FIFO)的容器。
   - 支持在队尾插入元素,在队头删除元素。
   - 常用的操作有 `push()`(入队)、`pop()`(出队)、`front()`(获取队头元素)、`back()`(获取队尾元素)等。

5. **Stack(栈)**:
   - 后进先出(LIFO)的容器。
   - 支持在栈顶压入元素和弹出元素。
   - 常用的操作有 `push()`(压栈)、`pop()`(出栈)、`top()`(获取栈顶元素)等。

6. **Map(映射)**:
   - 键值对的容器,每个键对应一个值。
   - 基于红黑树实现,保持元素有序。
   - 查找、插入、删除操作的时间复杂度为 O(log n)。

7. **Set(集合)**:
   - 存储唯一元素的容器,不允许重复元素。
   - 基于红黑树实现,保持元素有序。
   - 查找、插入、删除操作的时间复杂度为 O(log n)。

这些容器都有各自的特点和适用场景,你可以根据具体需求选择合适的容器类型。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/595479.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

N9048B PXE EMI 测试接收机,1 Hz 至 44 GHz

​ _EMI_ N9048B EMI 测试接收机 1 Hz 至 44 GHz Keysight N9048B PXE 是一款符合标准的 EMI 测试接收机&#xff0c;配有射频预选器和 LNA 设计。其实时扫描&#xff08;RTS&#xff09;功能有助于您缩短总体测试时间&#xff0c;轻松执行无间隙的信号捕获和分析。 特点 …

前后端功能实现——添加品牌

需求 点击新增&#xff0c;跳转到添加品牌的页面&#xff0c;从后一个页面提交品牌数据&#xff1a; 1、BrandMapper接口添加add()方法 /** * 添加品牌 */ void add(Brand brand); 2、BrandMapper.xml中添加sql方法 <insert id"add">insert into brand val…

【字符串】Leetcode 最长回文子串

题目讲解 5. 最长回文子串 算法讲解 dp[i][j]表示i~j这一段区间的子串是否是回文 当s[i] s[j]的时候&#xff0c;此时是有三种情况的&#xff1a; ij说明一个字符肯定是回文 i1 j也说明一个字符是回文 i1 < j说明需要判断[i1, j-1]这一段区间是否是回文 此时我们就可以…

代码随想录算法训练营第十三天:树的认知(补五一)

代码随想录算法训练营第十三天&#xff1a;树的认知&#xff08;补五一&#xff09; ‍ 二叉树的递归遍历 #算法公开课 《代码随想录》算法视频公开课 ****(opens new window)****​ &#xff1a;​每次写递归都要靠直觉&#xff1f; 这次带你学透二叉树的递归遍历&#xf…

[UDS][OTA] 自定义 IntelHEX (IHEX) format read/write library in C

参考修改 参考github的MIT协议开源项目 ihex 改写的代码 https://gitee.com/liudegui/intelhex-c 修改点&#xff1a; 修改Makefile脚本&#xff0c;支持x86_X64平台和aarch64平台将默认读取行长度设置为16位删除与ihex和bin之间的转换无关的示例代码 十六进制描述 HEX格式…

c#绘制渐变色的Led

项目场景&#xff1a; c#绘制渐变色的button using System; using System.ComponentModel; using System.Drawing; using System.Drawing.Drawing2D; using System.Windows.Forms; using static System.Windows.Forms.AxHost;namespace WindowsFormsApp2 {public class Gradie…

接口测试及常用的接口测试工具(Postman/Jmeter)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 首先&#xff0c;什么是接口呢&#xff1f; 接口一般来说有两种&#xff0c;一种是程序内部的接…

包管理工具npm、cnpm、yarn、NVM

[包]英文单词是package,代表了一组特定功能的源码集合 包管理工具&#xff1a; 管理[包]的应用软件,可以对[包]进行下载安装,更新,删除,上传等操作借助包管理工具,可以快速开发项目,提升开发效率 包管理工具是一个通用的概念,很多编程语言都有包管理工具,所以掌握好包管理工具非…

1.python爬虫爬取视频网站的视频可下载的源url

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、爬取的源网站二、实现代码总结 一、爬取的源网站 http://www.lzizy9.com/ 在这里以电影片栏下的动作片为例来爬取。 可以看到视频有多页&#xff0c;因此需要…

Java设计模式 _结构型模式_享元模式

一、享元模式 1、享元模式 享元模式&#xff08;Flyweight Pattern&#xff09;是一种结构型模式。主要用于减少创建对象的数量&#xff0c;以减少内存占用和提高性能。主要解决有大量对象时&#xff0c;有可能会造成内存溢出&#xff0c;我们把其中共同的部分抽象出来&#x…

(网络初识)

网络发展史 独立模式 在最开始计算机被发明出来&#xff0c;但网络还未普及的情况下&#xff0c;每个计算机之间都是相互独立的&#xff1a; 假设现在有一份数据需要处理&#xff0c;然后这份数据的处理又分给三个人分别处理。假设小松处理进行第一部分的处理&#xff0c;当小…

Java二维码、条码生成及解码工具类

功能描述 生成二维码、条码解码使用谷歌的zxing依赖 引入依赖 <dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.4.1</version> </dependency><dependency><groupId>…

2023ccpc深圳G题相似基因序列问题

样例&#xff1a; 6 4 4 1 kaki kika manu nana tepu tero kaka mana teri anan 输出&#xff1a; 2 2 1 0 解析&#xff1a; 如果是用暴力的话是 300*300*6000&#xff0c;这样子一定会超时。 这时候我们可以利用hash函数进行处理&#xff0c;对比一个字符串的小于为O&a…

打开3d模型时显示不匹配是什么原因---模大狮模型网

在当今数字化时代&#xff0c;3D模型在各个领域的应用越来越广泛&#xff0c;从建筑设计到工程制造&#xff0c;再到虚拟现实技术的发展&#xff0c;都需要使用到3D模型。然而&#xff0c;在打开3D模型时遇到显示不匹配的问题并非罕见&#xff0c;可能会给工作和项目带来不便。…

堡垒机——网络技术手段

目录 一、简介 1.什么是跳板机 2.跳板机缺陷 3.什么是堡垒机 4.为什么要使用堡垒机 4.1堡垒机设计理念 4.2堡垒机的建设目标 4.3堡垒机的价值 4.4总结 5.堡垒机的分类 6.堡垒机的原理 7.堡垒机的身份认证 8.堡垒机的运维方式常见有以下几种 9.堡垒机其他常见功能…

多线程详解

目录 1.线程的概念 2.进程和线程的区别 3.线程操作 4.线程互斥 5.可重入和线程安全 6.常见锁的概念 7.线程同步 1.线程的概念(lwp) 1.1 线程概念 (1) 线程是cpu调度的基本单位(轻量化的进程), 和进程不同的是进程是承担系统资源的基本实体. (2) 一个进程里面至少有一个线…

2024年电化学、可再生能源与绿色发展国际会议(ICERGD2024)

2024年电化学、可再生能源与绿色发展国际会议(ICERGD2024) 会议简介 2024国际电化学、可再生能源与绿色发展大会&#xff08;ICERGD2024&#xff09;将在青岛隆重举行。本次会议聚焦电化学、可再生能源和绿色发展领域的最新研究成果和技术趋势&#xff0c;旨在促进相关领域…

如何快速找出文件夹里的全部带有数字纯数字的文件

参考此文章&#xff1a;如何快速找出文件夹里的全部带有中文&纯中文的文件 只需要根据自己的需求&#xff0c;把下面相关的设置调整好即可

【电商-虾皮】

电商-虾皮 ■ 人口分布■ 市场■ 欧美市场■ 东南亚市场 ■ ■ 人口分布 ■ 市场 ■ 欧美市场 亚马逊 ■ 东南亚市场 shopee ■

如何通过前端表格控件在10分钟内完成一张分组报表?

前言&#xff1a; 当今时代&#xff0c;报表作为信息化系统的重要组成部分&#xff0c;在日常的使用中发挥着关键作用。借助报表工具使得数据录入、分析和传递的过程被数字化和智能化&#xff0c;大大提高了数据的准确性及利用的高效性。而在此过程中&#xff0c;信息化系统能…
最新文章