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

std::ranges::contains

std::ranges::contains 

std::ranges::contains 是 C++23 中引入的一个算法,用于检查一个范围中是否包含指定的值。它属于 <algorithm> 头文件,是范围库(Ranges Library)的一部分,提供更简洁、安全的范围操作。

Call signature

(1)
template< std::input_iterator I, std::sentinel_for<I> S,

          class T,
          class Proj = std::identity >
requires std::indirect_binary_predicate<ranges::equal_to, std::projected<I, Proj>,
                                        const T*>

constexpr bool contains( I first, S last, const T& value, Proj proj = {} );
(since C++23)
(until C++26)
template< std::input_iterator I, std::sentinel_for<I> S,

          class Proj = std::identity,
          class T = std::projected_value_t<I, Proj> >
requires std::indirect_binary_predicate<ranges::equal_to, std::projected<I, Proj>,
                                        const T*>

constexpr bool contains( I first, S last, const T& value, Proj proj = {} );
(since C++26)
(2)
template< ranges::input_range R,

          class T,
          class Proj = std::identity >
requires std::indirect_binary_predicate<ranges::equal_to,
                                        std::projected<ranges::iterator_t<R>, Proj>,
                                        const T*>

constexpr bool contains( R&& r, const T& value, Proj proj = {} );
(since C++23)
(until C++26)
template< ranges::input_range R,

          class Proj = std::identity,
          class T = std::projected_value_t<ranges::iterator_t<R>, Proj> >
requires std::indirect_binary_predicate<ranges::equal_to,
                                        std::projected<ranges::iterator_t<R>, Proj>,
                                        const T*>

constexpr bool contains( R&& r, const T& value, Proj proj = {} );
(since C++26)
template< std::forward_iterator I1, std::sentinel_for<I1> S1,

          std::forward_iterator I2, std::sentinel_for<I2> S2,
          class Pred = ranges::equal_to,
          class Proj1 = std::identity, class Proj2 = std::identity >
requires std::indirectly_comparable<I1, I2, Pred, Proj1, Proj2>
constexpr bool contains_subrange( I1 first1, S1 last1, I2 first2, S2 last2,
                                  Pred pred = {},

                                  Proj1 proj1 = {}, Proj2 proj2 = {} );
(3)(since C++23)
template< ranges::forward_range R1, ranges::forward_range R2,

          class Pred = ranges::equal_to,
          class Proj1 = std::identity, class Proj2 = std::identity >
requires std::indirectly_comparable<ranges::iterator_t<R1>,
                                    ranges::iterator_t<R2>, Pred, Proj1, Proj2>
constexpr bool contains_subrange( R1&& r1, R2&& r2, Pred pred = {},

                                  Proj1 proj1 = {}, Proj2 proj2 = {} );
  • 参数
    • r:要检查的输入范围。
    • value:要查找的值。
    • proj:投影函数(可选),用于对范围中的元素进行转换后再比较。
  • 返回值
    • 如果范围中存在等于 value 的元素,返回 true;否则返回 false

关键点

  1. 线性搜索:从范围起点开始逐个检查元素,直到找到目标值或遍历完整个范围。
  2. 复杂度:时间复杂度为 O(N),空间复杂度为 O(1)。
  3. 投影支持:允许通过 proj 对元素进行转换后再比较(例如查找对象的某个成员)。
  4. 范围安全性:直接操作范围,避免裸指针和迭代器的手动管理。

示例

示例 1:基本用法
#include <algorithm>
#include <vector>
#include <ranges>
#include <iostream>

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

    // 检查是否包含 3
    bool has_3 = std::ranges::contains(v, 3);
    std::cout << "Contains 3: " << has_3 << std::endl; // 输出 1(true)

    // 检查是否包含 6
    bool has_6 = std::ranges::contains(v, 6);
    std::cout << "Contains 6: " << has_6 << std::endl; // 输出 0(false)
}

输出:

Contains 3: 1
Contains 6: 0

示例 2:使用投影函数
#include <algorithm>
#include <vector>
#include <ranges>
#include <iostream>

struct Person {
    std::string name;
    int age;
};

int main() {
    std::vector<Person> people = {
        {"Alice", 25},
        {"Bob", 30},
        {"Charlie", 35}
    };

    // 检查是否存在年龄为 30 的人
    bool has_age_30 = std::ranges::contains(
        people,
        30,
        [](const Person& p) { return p.age; } // 投影:提取 age 成员
    );

    std::cout << "Has age 30: " << has_age_30 << std::endl; // 输出 1(true)
}

输出:

Has age 30: 1

应用场景

  1. 简单存在性检查:快速判断某个值是否在集合中。
  2. 条件过滤:结合投影函数检查对象成员的特定值。
  3. 字符串处理:检查字符或子字符串是否存在。

注意事项

  • C++23 支持:需确保编译器支持 C++23(如 GCC 13+、Clang 16+、MSVC 19.30+)。
  • 性能:对于大规模数据,线性搜索可能不够高效,此时建议使用 std::ranges::binary_search(需先排序)

如下container有自己的contains:

std::map::contains
std::set::contains
std::multimap::contains
std::multiset::contains
std::unordered_map::contains
std::unordered_set::contains
std::unordered_multimap::contains
std::unordered_multiset::contains

std::string::contains  C++23

std::array 和 std::vector没有定义contains,只能使用std::ranges::contains, STL并没有提供std::contains

相关文章:

  • 数仓搭建:DWB层(基础数据层)
  • Ubuntu 下 systemd 介绍
  • 应用案例 | uaGate SI助力汽车零部件工厂将生产数据传输到MES
  • 进阶——第十六届蓝桥杯嵌入式熟练度练习(开发板捕获频率和占空比)
  • 【云原生】最新版Kubernetes集群基于Containerd部署
  • VMware 17 安装 VMTools(win 7旗舰 X64)
  • 使用redis分布式锁来解决高并发场景
  • MySQL中的事务隔离级别有哪些?
  • 基于STM32、HAL库、FM24CL64(I2C接口)驱动程序设计
  • 达梦数据库针对慢SQL,收集统计信息清除执行计划缓存
  • VScode内接入deepseek包过程(本地部署版包会)
  • 【网络编程】之数据链路层
  • 使用卷积神经网络(CNN)对颜色失真情况下进行数字识别
  • 【全栈】SprintBoot+vue3迷你商城-细节解析(1):Token、Jwt令牌、Redis、ThreadLocal变量
  • 请谈谈 em、px、rem、vh、vw 的区别,如何使用?
  • ubuntu20动态修改ip,springboot中yaml的内容的读取,修改,写入
  • 打造智能语料库:通过Coco AI Server 实现 Notion 笔记 RAG 检索功能
  • vue3项目实践心得-寻找未被使用的最小编号
  • LVGL图形界面编程(基础篇): 一.LVGL入门
  • 单表数据文件坏块检查及恢复
  • 西安网站制作工商/设计好看的网站
  • 扶贫基金会网站建设是哪家公司/举三个成功的新媒体营销案例
  • 网站建设与网页设计可行性分析报告/北京营销推广网站建设
  • 怎样查公司是不是正规公司/电影站的seo
  • qq空间怎么做网站/国家卫健委最新疫情报告
  • 仿一个展示型网站多少钱/百度推广一个关键词多少钱