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

专业的无锡网站建设如何做招聘网站效果评估

专业的无锡网站建设,如何做招聘网站效果评估,校园网站psd,云商城是什么平台std::ranges::contains std::ranges::contains 是 C23 中引入的一个算法&#xff0c;用于检查一个范围中是否包含指定的值。它属于 <algorithm> 头文件&#xff0c;是范围库&#xff08;Ranges Library&#xff09;的一部分&#xff0c;提供更简洁、安全的范围操作。 C…

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};// 检查是否包含 3bool has_3 = std::ranges::contains(v, 3);std::cout << "Contains 3: " << has_3 << std::endl; // 输出 1(true)// 检查是否包含 6bool 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

http://www.dtcms.com/wzjs/801167.html

相关文章:

  • 网站模版制作wordpress 首页重定向
  • 福建城市建设厅网站最新国内你新闻
  • wap的网站模板张家口高新区做网站
  • 做网站建设需要什么工具用wix做网站需要备案吗
  • 做响应式网站所用的代码wordpress栏目标题被调用
  • 镇江教育云网站建设什么是网站站点建设介绍
  • 做母婴网站设计思路常州网站推广方法
  • 股票配资网站建设建网站联系
  • 景安一个空间怎么做多个网站网站设置反爬虫的常用方法有哪些
  • 设计网站推荐视频深圳网站建设公司流程
  • 物流公司网站模版搜索引擎优化不包括
  • 的网站建设公司那个好成都网站建设公司服务
  • 广州网站定制公司宣传网页
  • 网站文化建设易点科技有限公司
  • 企业网站建设方案大全网络推广的方法有多选题
  • 深圳建设企业网站怎么做一个好的wordpress
  • 白酒包装设计网站做网站的软件项目进度计划
  • 7星彩网站开发宜昌高端网站建设
  • .net网站架设网络营销建设网站实训
  • 万载网站建设网站制作教程及流程
  • ftp怎么找网站后台成都网站建设方案优化
  • 湖南省做网站那个企业便宜做投票网站的
  • 最大郑州网站建设公司PHP搭建IDC网站
  • 包头市做网站物联网平台网站开发
  • 安徽专业网站制作公司网站为什么要备案
  • 网站价格评估 优帮云自己能建设网站
  • 比一网站建设成都金融网站建设公司排名
  • 瀑布式网站企业所得税怎样计算
  • 常州西站建设规划云南网站建设维护
  • 临汾做网站公司哪家好深夜睡不着一个人看的正能量