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

站长工具ip查询外贸平台实训总结

站长工具ip查询,外贸平台实训总结,阳江房管局查询房产信息网,北京信息维护公司文章目录 引言C Ranges 库简介ranges::find_last、ranges::find_last_if 和 ranges::find_last_if_not 概述ranges::find_last示例代码代码解释 ranges::find_last_if函数签名参数解释示例代码代码解释 ranges::find_last_if_not示例代码代码解释 使用场景总结 引言 在 C 的发…

文章目录

    • 引言
    • C++ Ranges 库简介
    • `ranges::find_last`、`ranges::find_last_if` 和 `ranges::find_last_if_not` 概述
      • `ranges::find_last`
        • 示例代码
        • 代码解释
      • `ranges::find_last_if`
        • 函数签名
        • 参数解释
        • 示例代码
        • 代码解释
      • `ranges::find_last_if_not`
        • 示例代码
        • 代码解释
    • 使用场景
    • 总结

引言

在 C++ 的发展历程中,每一个新版本都会带来一系列令人期待的新特性,C++23 也不例外。其中,ranges 库进一步增强,支持更多的范围操作,ranges::find_lastranges::find_last_ifranges::find_last_if_not 就是 ranges 库中新增的非常实用的算法。这些算法为开发者提供了更加便捷、高效的方式来查找序列中的元素,尤其是在需要从后往前查找元素的场景中。本文将详细介绍这三个算法的定义、功能、使用场景以及使用示例。

C++ Ranges 库简介

C++ Ranges 库是 C++20 标准的一部分,它为 C++ 标准库引入了一种新的范式,旨在提供更现代、更安全、更高效的方式来处理序列和算法。Ranges 库通过引入范围(ranges)、视图(views)、适配器(adaptors)等概念,使得对序列的操作更加灵活和表达力更强。

在传统的 C++ 中,操作序列通常涉及迭代器(iterators)和算法(algorithms),这种方式虽然强大,但往往代码冗长且容易出错。Ranges 库的出现,正是为了解决这些问题,它将迭代器和算法的操作抽象成更高层次的范围操作,使得代码更加简洁、清晰,同时也更加安全。

ranges::find_lastranges::find_last_ifranges::find_last_if_not 概述

ranges::find_last

std::ranges::find_last 函数是 C++ 的一个算法,用于在给定范围内查找指定值的最后一次出现位置。它返回一个迭代器,指向范围中找到的元素;如果未找到该值,则返回结束迭代器。

示例代码
#include <iostream> 
#include <vector> 
#include <ranges> int main() {std::vector<int> numbers = {1, 2, 3, 4, 5, 3, 6};auto it = std::ranges::find_last(numbers, 3);if (it != numbers.end()) {std::cout << "Found last occurrence at index: " << std::distance(numbers.begin(), it) << std::endl;} else {std::cout << "Value not found." << std::endl;}return 0; 
}
代码解释

在上述示例中,我们定义了一个包含整数的向量 numbers,然后使用 std::ranges::find_last 函数查找值为 3 的元素的最后一次出现位置。如果找到,我们输出该元素的索引;否则,输出未找到的信息。

ranges::find_last_if

std::ranges::find_last_if 函数用于在给定范围内查找满足特定条件的最后一个元素。它返回一个迭代器,指向范围中满足条件的最后一个元素;如果未找到这样的元素,则返回结束迭代器。

函数签名
// (1)
constexpr ranges::subrange<I>find_last_if( I first, S last, Pred pred, Proj proj = {} );
// (2)
constexpr ranges::borrowed_subrange_t<R>find_last_if( R&& r, Pred pred, Proj proj = {} );
参数解释
  • firstlast:表示要检查的元素范围。
  • r:表示要检查的元素范围。
  • pred:用于应用于投影元素的谓词。
  • proj:用于应用于元素的投影。
示例代码
#include <iostream> 
#include <vector> 
#include <algorithm> 
#include <ranges> bool isEven(int num) {return num % 2 == 0; 
}int main() {std::vector<int> numbers = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};auto it = std::ranges::find_last_if(numbers, isEven);if (it != numbers.end()) {std::cout << "Last even number found: " << *it << std::endl;} else {std::cout << "No even number found." << std::endl;}return 0; 
}
代码解释

在上述示例中,我们定义了一个包含整数的向量 numbers,然后使用 std::ranges::find_last_if 函数查找最后一个偶数。如果找到,我们输出该偶数;否则,输出未找到的信息。

ranges::find_last_if_not

std::ranges::find_last_if_not 函数用于在给定范围内查找不满足特定条件的最后一个元素。它返回一个迭代器,指向范围中不满足条件的最后一个元素;如果未找到这样的元素,则返回结束迭代器。

示例代码
#include <iostream> 
#include <vector> 
#include <algorithm> 
#include <ranges> bool isEven(int num) {return num % 2 == 0; 
}int main() {std::vector<int> numbers = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};auto it = std::ranges::find_last_if_not(numbers, isEven);if (it != numbers.end()) {std::cout << "Last odd number found: " << *it << std::endl;} else {std::cout << "No odd number found." << std::endl;}return 0; 
}
代码解释

在上述示例中,我们定义了一个包含整数的向量 numbers,然后使用 std::ranges::find_last_if_not 函数查找最后一个奇数。如果找到,我们输出该奇数;否则,输出未找到的信息。

使用场景

这三个算法在很多场景中都非常有用,例如:

  • 数据处理:在处理大量数据时,可能需要从后往前查找满足特定条件的元素。
  • 日志分析:在分析日志文件时,可能需要查找最后一次出现的特定事件。
  • 文本处理:在处理文本时,可能需要查找最后一个符合某种规则的字符或字符串。

总结

C++23 中的 ranges::find_lastranges::find_last_ifranges::find_last_if_not 算法为开发者提供了更加便捷、高效的方式来从后往前查找序列中的元素。这些算法与 Ranges 库的其他功能相结合,可以使代码更加简洁、清晰,同时也提高了代码的安全性和可维护性。希望本文的介绍能帮助你更好地理解和使用这些算法。

http://www.dtcms.com/a/403268.html

相关文章:

  • 在JavaScript / HTML中,让<audio>元素中的多个<source>标签连续播放
  • 【Web前端|第二篇】JavaScript对象和事件
  • Linux配置网络————设置虚拟机为静态ip的网络配置详细教程
  • EPGF 架构为什么能保持长效和稳定?
  • reader should realize that all properties of real numbers that are to句子分析
  • ubuntu安装失败:Sorry, there was a problem completing the installation.原因分析及解决办法
  • 深圳商城网站设计价格网站轮播广告
  • AR技术:轨道交通运维与安全保障的革新力量
  • 友元类和友元函数bug
  • Zabbix7.4.8(二):通过http监控Nginx相关指标
  • 厦门 外贸网站访问数据库的网站开发语言
  • Gerkin+Pytest(python)实现自动化(BDD)
  • 动态住宅IP vs. 静态数据中心IP:未来趋势与当前选择
  • 子域名做微信开放平台网站应用芜湖企业100强
  • 很那网站建设做网站哪个公司好
  • Kafka的核心概念
  • Zookeeper 与 Kafka
  • 巴斯勒相机:30 年技术沉淀,重新定义机器视觉效率​
  • 【Kotlin进阶】泛型的高级特性
  • h.265格式的视频在浏览器无法正常播放,使用ffprobe转为h.264
  • sysbench mysql 单表 insert 压测 , 自定义lua测试脚本
  • 石家庄制作网站的公司电商流量平台
  • 二手车网站html模板西宁网站设计
  • 零成本上线动态博客:用 Rin + Cloudflare 部署个人博客的完整指南
  • 家用净水器DIY,75G经典5级Ro净水器
  • 七、OpenCV中的视频的读写
  • ClipboardApp —— Mac 专属轻量级剪切板助手(开源)
  • 【开题答辩全过程】以 LoveEditing视频编辑社团网站为例,包含答辩的问题和答案
  • ARM芯片架构之CoreSight ROM Table 的SoC设计思路
  • 门户网站建设的平台搭建hello md5 wordpress