当前位置: 首页 > news >正文

C++ 补充之常用遍历算法

在这里插入图片描述

C++遍历算法和原理

C++标准库提供了丰富的遍历算法,涵盖了各种不同的功能。以下是一些常见的C++遍历算法以及它们的概念和原理的简要讲解:

  1. for_each:对容器中的每个元素应用指定的函数。

    • 概念:对于给定的容器和一个可调用对象,该算法将依次对容器中的每个元素调用该可调用对象。
    • 原理:通过迭代器遍历容器,对每个元素都应用给定的可调用对象。
  2. find:在容器中查找指定值第一次出现的位置。

    • 概念:给定一个容器和一个值,该算法返回指向第一个等于该值的元素的迭代器。若未找到,则返回迭代器指向容器的末尾。
    • 原理:通过线性搜索,逐个比较容器中的元素与指定的值,直到找到相等的元素。
  3. find_if:在容器中查找满足条件的第一个元素。

    • 概念:给定一个容器和一个谓词(可判断元素是否满足条件的函数或函数对象),该算法返回指向第一个满足条件的元素的迭代器。若未找到,则返回迭代器指向容器的末尾。
    • 原理:通过线性搜索,逐个对容器中的元素应用谓词,直到找到满足条件的元素。
  4. count:统计某个值在容器中出现的次数。

    • 概念:给定一个容器和一个值,该算法返回容器中与该值相等的元素的数量。
    • 原理:通过迭代器遍历容器,对每个元素与给定值进行比较并计数。
  5. sort:对容器中的元素进行排序。

    • 概念:对给定的容器中的元素进行排序,按一定的排序规则进行。
    • 原理:使用排序算法(如快速排序、归并排序等)对容器中的元素进行排序。
  6. transform:对容器中的每个元素执行某种转换。

    • 概念:给定一个容器和一个转换操作(比如函数、函数对象),该算法会对容器中的每个元素进行转换操作,并将结果存储在另一个容器中。
    • 原理:通过迭代器遍历容器,对每个元素应用给定的转换操作并将结果存储到另一容器中。
  7. copy:将容器中的元素复制到另一个容器中。

    • 概念:给定一个源容器和一个目标容器,该算法将源容器中的元素复制到目标容器中,并返回指向目标容器最后一个元素之后位置的迭代器。
    • 原理:通过迭代器遍历源容器,将每个元素复制到目标容器中。
  8. reverse:反转容器中的元素顺序。

    • 概念:给定一个容器,该算法将容器中的元素顺序进行反转。
    • 原理:通过迭代器遍历容器,使用两个迭代器指向首尾元素,依次交换它们的值,从而达到反转顺序的目的。
  9. unique:去除容器中相邻重复的元素。

    • 概念:给定一个容器,该算法移除容器中连续出现的重复元素,只保留其中一个。
    • 原理:通过迭代器遍历容器,比较相邻的元素并移除重复元素。
  10. adjacent_find:查找容器中相邻重复的元素。

    • 概念:给定一个容器,该算法返回指向第一组连续相同元素的迭代器。若未找到,则返回迭代器指向容器的末尾。
    • 原理:通过线性搜索,逐个比较容器中的相邻元素,找到第一组相同元素。

以上是一些常见的C++遍历算法的概念和原理简介。通过使用这些算法,可以方便地对容器中的元素进行各种不同的操作和处理。

今天要讲的遍历算法是:foreach,transform,find

在这里插入图片描述

C++遍历算法for_each

在C++标准库中,并没有名为foreach的遍历算法,但是可以通过使用for_each算法来达到类似的效果。for_each算法是对容器中的每个元素应用指定的函数。下面我将详细介绍for_each算法并举例说明其用法:
在这里插入图片描述

for_each算法概念:
for_each算法接受一个可调用对象(函数、函数对象或Lambda表达式)和一个范围(通常是容器),然后对范围内的每个元素都依次调用这个可调用对象。它不会改变容器中的元素,只是对每个元素进行处理。

示例代码:

#include <iostream>
#include <vector>
#include <algorithm>void printSquare(int x) {std::cout << x * x << " ";
}int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};// 使用for_each算法,对容器中的每个元素调用printSquare函数std::for_each(numbers.begin(), numbers.end(), printSquare);return 0;
}

示例解释:

  1. 在示例代码中,我们首先定义了一个打印平方的函数printSquare。
  2. 然后定义了一个包含数字的vector容器numbers。
  3. 在主函数中,我们使用for_each算法,对numbers容器中的每个元素都调用printSquare函数,输出每个元素的平方值。
  4. 最后程序输出结果为:1 4 9 16 25。

通过for_each算法,可以方便地对容器中的每个元素进行操作,而不需要显式地编写循环。可以根据实际需求传入不同的函数或Lambda表达式来对容器中的元素进行处理。

C++遍历算法transform

transform算法概念:
transform算法用于对序列中的每个元素应用指定的操作,并将结果存储在另一个序列中。这个算法可以看作是一种投影操作,将一个序列映射到另一个序列。

示例代码:

#include <iostream>
#include <vector>
#include <algorithm>int square(int x) {return x * x;
}int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};std::vector<int> squared_numbers;// 使用transform算法,将numbers中的每个元素求平方,存储到squared_numbers中std::transform(numbers.begin(), numbers.end(), std::back_inserter(squared_numbers), square);// 输出squared_numbers中的元素for (int num : squared_numbers) {std::cout << num << " ";}return 0;
}

示例解释:

  1. 在示例代码中,我们定义了一个函数square,用于计算输入的值的平方。
  2. 首先创建了一个包含数字的vector容器numbers和一个空的vector容器squared_numbers。
  3. 然后使用transform算法,将numbers中的每个元素应用square函数进行平方操作,结果存储在squared_numbers中。
  4. 最后使用for循环打印输出squared_numbers中的元素,即每个数的平方值。
  5. 输出结果为:1 4 9 16 25。

通过transform算法,可以方便地对容器中的每个元素进行转换操作,并将结果存储在另一个容器中,减少了显式循环的编写。 transform算法提供了一种简洁而高效的方法来处理容器元素的映射操作。

C++遍历算法find

find算法概念:
find算法用于在容器中查找指定值第一次出现的位置,返回指向第一个等于该值的元素的迭代器,若未找到,则返回迭代器指向容器的末尾。
在这里插入图片描述

示例代码:

#include <iostream>
#include <vector>
#include <algorithm>int main() {std::vector<int> numbers = {1, 2, 3, 4, 5};// 在numbers中查找值为3的元素auto it = std::find(numbers.begin(), numbers.end(), 3);// 判断是否找到if (it != numbers.end()) {std::cout << "找到了值为3的元素,位置在索引 " << std::distance(numbers.begin(), it) << std::endl;} else {std::cout << "未找到值为3的元素" << std::endl;}return 0;
}

示例解释:

  1. 示例代码定义了一个包含数字的vector容器numbers。
  2. 使用find算法在numbers中查找值为3的元素,将返回值为3的元素的迭代器。
  3. 判断返回的迭代器是否指向了容器末尾,如果没有,打印出找到元素的位置;否则提示未找到元素。
  4. 输出结果为:“找到了值为3的元素,位置在索引 2”。

通过find算法,可以快速在容器中查找特定值第一次出现的位置。如果找到了指定值,find将返回指向该元素的迭代器;否则返回迭代器指向容器末尾,可以通过判断迭代器是否等于end()来确定是否找到了目标元素。这个算法在实际开发中经常被使用。

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步

相关文章:

C++ 补充之常用遍历算法

C遍历算法和原理 C标准库提供了丰富的遍历算法&#xff0c;涵盖了各种不同的功能。以下是一些常见的C遍历算法以及它们的概念和原理的简要讲解&#xff1a; for_each&#xff1a;对容器中的每个元素应用指定的函数。 概念&#xff1a;对于给定的容器和一个可调用对象&#xff…...

【Linux杂货铺】调试工具gdb的使用

目录 &#x1f308;前言&#x1f308; &#x1f4c1;背景介绍 &#x1f4c1; 使用 list [行号] / [函数名] run/r break/b [行号] / [函数名] info break disable break enable break delete break [断点编号] next/n step/s continue/c finish print/p [变量…...

FL Studio Producer Edition2024中文进阶版Win/Mac

FL Studio Producer Edition&#xff0c;特别是其【中文进阶版 Win/Mac】&#xff0c;是数字音乐制作领域中的一款知名软件。它为广大音乐制作人、声音工程师以及音乐爱好者提供了一个从音乐构思到最终作品发布的完整解决方案。这个版本特别为中文用户优化&#xff0c;并兼容W…...

无需邀请码,Xinstall实现精准分享归因

在如今的移动互联网时代&#xff0c;分享已经成为了我们日常生活中不可或缺的一部分。无论是社交媒体上的好友分享&#xff0c;还是应用内的内容分享&#xff0c;分享都能够帮助我们快速传播信息&#xff0c;扩大影响力。然而&#xff0c;对于开发者而言&#xff0c;分享却带来…...

机器人与AGI会撞出什么火花?

真正的科技变革是不是就要来临了&#xff1f;各方大佬都开始布局机器人&#xff0c;对于普通人的就业会造成什么影响&#xff1f; ​ 优牛企讯-企业动态信息监控专家 在优牛企讯-企业动态监控专家搜索可知&#xff0c;全国目前的机器人公司已经达到了26401家&#xff0c;近一年…...

Linux yum安装pgsql出现Bad GPG signature错误

官方文档&#xff1a;https://www.postgresql.org/download/linux/redhat/ sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm sudo yum install -y postgresql12-server sudo /usr/pgsql-12/bin/…...

第18章-DHCP

1. 产生背景 2. 概述 2.1 定义 2.2 特点 2.3 DHCP系统组成 3. DHCP工作原理 3.1 前提条件 3.2 场景 3.3 分配IP地址工作机制 3.4 特殊情况处理 3.5 IP地址租约更新 4. DHCP中继代理 4.1 现实场景 4.2 工作机制 1. 产生背景 现实问题&#xff1a; 小型网络中&…...

[物联网] OneNet 多协议TCP透传

[物联网] OneNet 多协议TCP透传 STM32物联网–ONENET云平台的多协议接入产品创建 : https://blog.csdn.net/qq_44942724/article/details/134492924 Onenet tcp 透传 : https://blog.csdn.net/flyme2010/article/details/107086001 tcp服务端测试工具 : http://tcp.xnkiot.com/…...

如何让网页APP化 渐进式Web应用(PWA)

前言 大家上网应该发现有的网页说可以安装对应应用&#xff0c;结果这个应用好像就是个web&#xff0c;不像是应用&#xff0c;因为这里采用了PWA相关技术。 PWA&#xff0c;全称为渐进式Web应用&#xff08;Progressive Web Apps&#xff09;&#xff0c;是一种可以提供类似…...

50 vmalloc 的实现

前言 这里说的是 内核中分配按页分配的场景 常用于 驱动什么的, 分配 中大型空间 由于 连续的 n 个页是分别使用 alloc_pages 分配的, 因此是 虚拟地址空间连续, 但是 物理地址空间不连续 如何分配对象 两个步骤, __get_vm_area_node 获取为 size 分配的 vma 区间, 然后…...

程序员的金三银四求职宝典!

目录 ​编辑 程序员的金三银四求职宝典 一、为什么金三银四是程序员求职的黄金时期&#xff1f; 二、如何准备金三银四求职&#xff1f; 1. 完善简历 2. 增强技术能力 3. 提前考虑目标公司 4. 提前准备面试 三、程序员求职的常见面试题 1. 数据结构和算法 2. 数据库 …...

day04_拦截器Apifox角色管理(登录校验,API接口文档,权限管理说明,角色管理,添加角色,修改角色,删除角色)

文章目录 1. 登录校验1.1 需求说明1.2 实现思路1.3 ThreadLocal1.4 AuthContextUtil1.5 拦截器使用1.5.1 拦截器开发1.5.2 拦截器注册 1.6 代码优化1.6.1 配置优化1.6.2 代码优化1.6.3 前端修改 2. API接口文档2.1 Apifox接口管理平台2.1.1 接口管理平台简介2.1.2 Apifox简介2.…...

在线上传解压PHP文件代码,压缩/压缩(网站一键打包)支持密码登录

在线上传解压PHP文件代码&#xff0c;压缩/压缩(网站一键打包)支持密码登录 资源宝分享&#xff1a;www.httple.net 如果你没有主机控制面板这个是最好选择&#xff0c;不需要数据库&#xff0c;上传当控制面板使用&#xff0c;无需安装任何扩展&#xff0c;安全高&#xff0c;…...

【刷题】模拟

模拟算法&#xff1a;题目中已经告诉应该怎么做了&#xff0c;只需要模拟即可&#xff0c;思路比较简单&#xff0c;比较考察代码能力。 一般先在草稿纸上模拟流程&#xff0c;如果直接写代码&#xff0c;容易忽视细节&#xff0c;并且不容器调试&#xff01; 优化策略&#…...

【打工日常】使用docker部署在线Photopea用于linux下替代ps

一、Photopea介绍 linux没有ps适配&#xff0c;对于有时候工作来说确实不方便&#xff0c;我找了很久&#xff0c;才找到了一款功能可以跟ps接近的在线软件&#xff0c;使用docker部署就可以了。它是ps的最佳替代品之一&#xff0c;其界面几乎与ps相同&#xff0c;只不过它是在…...

leetcode 热题 100_盛最多水的容器

题解一&#xff1a; 双指针遍历&#xff1a;容量计算公式为min(左高度&#xff0c;右高度)*底部距离&#xff0c;我们可以令底部距离逐步递减&#xff08;左右两边的指针向中部移动&#xff09;。此时对于min(左高度&#xff0c;右高度)&#xff0c;假设较高的线向中部移动&…...

基本正则表达式

基本正则表达式 正则命令功能&#xff3e;尖角号&#xff0c;用于模式的最左侧&#xff0c;如“^oldbpy"&#xff0c;匹配以oldboy单词开头的行$美元符&#xff0c;用于模式的最右侧&#xff0c;如"oldboy$"&#xff0c;表示以oldboy单词结尾的行^$组合符&…...

sqlserver保存微信Emoji表情

首先将数据库字段&#xff0c;设置类型为 nvarchar(200)一个emoji表情&#xff0c;占4字节就可以了&#xff0c;web前端展示不用改任何东西&#xff0c;直接提交数据保存&#xff1b;回显也会没有问题&#xff0c;C#代码不用做任何处理&#xff1b; 不哭不闹要睡觉&#x1f31…...

网络编程 io_uring

io_uring 1、概述 io_uring是Linux&#xff08;内核版本在5.1以后&#xff09;在2019年加入到内核中的一种新型的异步I/O模型&#xff1b; io_uring使用共享内存&#xff0c;解决高IOPS场景中的用户态和内核态的切换过程&#xff0c;减少系统调用&#xff1b;用户可以直接向…...

Java中的static

Java中的static 同一个类的静态变量共享同一个内存空间&#xff0c;即静态变量也就是被 static 关键字修饰的变量。它可以被类的所有实例共享&#xff0c;无论一个类创建了多少个对象&#xff0c;它们都共享同一份静态变量。从变量在内存中的存储方式来看&#xff0c;如果成员…...

Oracle查询表空间大小

1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...

云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地

借阿里云中企出海大会的东风&#xff0c;以**「云启出海&#xff0c;智联未来&#xff5c;打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办&#xff0c;现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

【磁盘】每天掌握一个Linux命令 - iostat

目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat&#xff08;I/O Statistics&#xff09;是Linux系统下用于监视系统输入输出设备和CPU使…...

Golang dig框架与GraphQL的完美结合

将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用&#xff0c;可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器&#xff0c;能够帮助开发者更好地管理复杂的依赖关系&#xff0c;而 GraphQL 则是一种用于 API 的查询语言&#xff0c;能够提…...

Nginx server_name 配置说明

Nginx 是一个高性能的反向代理和负载均衡服务器&#xff0c;其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机&#xff08;Virtual Host&#xff09;。 1. 简介 Nginx 使用 server_name 指令来确定…...

IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)

文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...

Xen Server服务器释放磁盘空间

disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)

船舶制造装配管理现状&#xff1a;装配工作依赖人工经验&#xff0c;装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书&#xff0c;但在实际执行中&#xff0c;工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...

Selenium常用函数介绍

目录 一&#xff0c;元素定位 1.1 cssSeector 1.2 xpath 二&#xff0c;操作测试对象 三&#xff0c;窗口 3.1 案例 3.2 窗口切换 3.3 窗口大小 3.4 屏幕截图 3.5 关闭窗口 四&#xff0c;弹窗 五&#xff0c;等待 六&#xff0c;导航 七&#xff0c;文件上传 …...