C++初学者指南-5.标准库(第一部分)--标准库查询存在算法

C++初学者指南-5.标准库(第一部分)--标准库查询存在算法

文章目录

不熟悉 C++ 的标准库算法? ⇒ 简介

any_of / all_of / none_of

如果在输入范围(所有元素,任意一个元素或没有元素)内check的结果为true,则返回true。
cppreference

cpp 复制代码
std::vector<int> v {0,2,9,1,3,8,5,2,9};
auto const check = [](int x) { return x >= 1; };
// 在子范围内(如图所示):
cout << all_of (begin(v)+1, begin(v)+7, check);  // true
cout << any_of (begin(v)+1, begin(v)+7, check);  // true
cout << none_of(begin(v)+1, begin(v)+7, check);  // false
// 整个vector:
cout << all_of (begin(v), end(v), check);  // false
cout << any_of (begin(v), end(v), check);  // true
cout << none_of(begin(v), end(v), check);  // false

运行示例代码

cppreference

cpp 复制代码
std::vector<int> v {0,2,9,1,3,8,5,2,9};
auto const check = [](int x) { return x >= 1; };
cout << std::ranges::all_of (v, check);  // false
cout << std::ranges::any_of (v, check);  // true
cout << std::ranges::none_of(v, check);  // false

运行示例代码

count


cppreference

cpp 复制代码
std::vector<int> v {5,2,9,1,3,2,5,2,2,9};
// 子范围内计数(如图所示):
auto n = count(begin(v)+1, begin(v)+8, 2);  // n = 3
// 整个vector计数:
auto m = count(begin(v), end(v), 2);  // m = 4

运行示例代码

cppreference

cpp 复制代码
std::vector<int> v {2,9,1,3,2,5,2};
cout << std::ranges::count(v, 3);  // 1
cout << std::ranges::count(v, 2);  // 3
cout << std::ranges::count(v, 7);  // 0

运行示例代码

count_if


cppreference

cpp 复制代码
std::vector<int> v {5,4,9,1,3,2,5,6,8,9};
auto const is_even = [](int x) { return !(x & 1); };
// 子范围内计数(如图所示):
auto n = count_if (begin(v)+1, begin(v)+8, is_even);  // n = 3
// 整个vector计数:
auto m = count_if (begin(v), end(v), is_even);  // m = 4

运行示例代码

cppreference

cpp 复制代码
std::vector<int> v {4,9,1,3,2,5,6};
auto const is_even = [](int x) { return !(x & 1); };
auto n = std::ranges::count_if(v, is_even);  // n = 3

运行示例代码

相关内容

视频:count, count_if and more by Conor Hoekstra
标准算法概述
C++标准库算法介绍
标准序列容器(vector、deque、list、...)
标准关联容器(map、set、...)
标准序列视图
cppreference:算法库
cppreference:容器库
视频:什么是 C++ 标准库?
视频:一小时内掌握 105 个 STL 算法 (Jonathan Boccara,2018)
C++ 之旅:容器和算法

算法概述表:

附上原文链接

如果文章对您有用,请随手点个赞,谢谢!^_^

相关推荐
夜泉_ly32 分钟前
MySQL -安装与初识
数据库·mysql
qq_529835352 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New4 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6754 小时前
数据库基础1
数据库
我爱松子鱼4 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo4 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
计算机小白一个4 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^5 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
黑不溜秋的5 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
Rverdoser5 小时前
【SQL】多表查询案例
数据库·sql