C++__min_element()和max_element()函数的使用
C++__min_element()和max_element()函数的使用
今天在leetcode练习题目时遇到了min_element(),在此学习下min_element()与max_element()。
1、min_element
返回范围内的最小元素
返回指向范围内最小值的元素的迭代器[first,last)
。
如果没有其他元素比一个元素最小,则该元素是最小的。如果有多个元素满足此条件,则迭代器返回指向此类元素中第一个的点。
default (1) :
template <class ForwardIterator>ForwardIterator min_element (ForwardIterator first, ForwardIterator last);
custom (2) :
template <class ForwardIterator, class Compare>ForwardIterator min_element (ForwardIterator first, ForwardIterator last,Compare comp);
参数意义:
first, last:将迭代器输入到要比较的序列的初始位置和最终位置。使用的范围是[first,last),它包含first和last之间的所有元素,包括first指向的元素,但last指向的元素。
comp:二进制函数,该函数接受范围内的两个元素作为参数,并返回可转换为的值bool。返回的值指示作为第一个参数传递的元素是否小于第二个。该函数不得修改其任何参数。这可以是一个函数指针或一个函数对象。
返回值范围内最小值的迭代器;如果范围为空,则为最后一个迭代器。
返回为迭代器,所以要用*的方式解引用
2、max_element与min_element一样
示例:
#include <iostream> // std::cout
#include <algorithm> // std::min_element, std::max_elementbool myfn(int i, int j) { return i<j; }struct myclass {bool operator() (int i,int j) { return i<j; }
} myobj;int main () {int myints[] = {3,7,2,5,6,4,9};// using default comparison:std::cout << "The smallest element is " << *std::min_element(myints,myints+7) << '\n';std::cout << "The largest element is " << *std::max_element(myints,myints+7) << '\n';// using function myfn as comp:std::cout << "The smallest element is " << *std::min_element(myints,myints+7,myfn) << '\n';std::cout << "The largest element is " << *std::max_element(myints,myints+7,myfn) << '\n';// using object myobj as comp:std::cout << "The smallest element is " << *std::min_element(myints,myints+7,myobj) << '\n';std::cout << "The largest element is " << *std::max_element(myints,myints+7,myobj) << '\n';return 0;
}
输出结果为:
C++__min_element()和max_element()函数的使用相关推荐
- max函数|C++返回数组中的最大值——max_element函数
定义在<algorithm>里面 用法如下: int a[5] = {0, 3, 9, 4, 5}; int *b; b = max_element(a, a+5); cout <& ...
- stl max函数_std :: max_element()函数以及C ++ STL中的示例
stl max函数 C ++ STL std :: max_element()函数 (C++ STL std::max_element() function) max_element() functi ...
- C++:求极值的 min_element、max_element和minmax_element算法
(1)min_element()函数:会返回一个指向输入序列的最小元素的迭代器: (2)max_element()函数:会返回指向最大元素的迭代器: (3)minmax_element()函数:会以 ...
- 【C++】max_element()以及min_element()
0x00 前言 最后更新日期:2022-09-26 0x01 max_element()以及min_element() max_element()用于从范围[first, last)中获取最大值的元素 ...
- stl向量最大值_C ++ STL中向量的最小和最大元素
stl向量最大值 Given a vector and we have to find the smallest (minimum) and largest (maximum) elements. 给 ...
- dp动态规划_最长上升子序列问题
例题 最长上升子序列 一个数的序列ai,当a1 < a2 < ... < aS的时候,我们称这个序列是上升的. 对于给定的一个序列(a1, a2, ..., aN),我们可以得到一 ...
- 堆和栈的概念和区别 python_C++堆用法详解
堆(heaps)是一种特殊的数据组织方式,STL 中的 priority_queue 容器适配器底层就是采用堆来组织数据存储的.为了弄明白堆是什么,首先要搞清楚什么是树存储结构. 树是分层排列的元素或 ...
- c++ heap (堆)
1. 概述 堆(也叫优先队列),是一棵完全二叉树,它的特点是父节点的值大于(小于)两个子节点的值(分别称为大顶堆和小顶堆).它常用于管理算法执行过程中的信息,应用场景包括堆排序,优先队列等 2. 堆的 ...
- leetcode汇总
一.题目汇总 1.快速幂算法 暴力 分治 二.涉及的c++语法 1.long long 类型 .很大的无符号 long long类型 unsigned long long 和uint64_t 作为标记 ...
最新文章
- win32ctypes.pywin32.pywintypes.error: (2, ‘LoadLibraryEx‘, ‘系统找不到指定的文件。‘)
- delphi实现两个目录路径的链接
- unused import statement
- R,让你的数据分析更简便!
- 古老的spc也可以用机器学习(三)-支持向量机算法
- 前端学习(96):切图流程
- Java并发编程之线程定时器ScheduledThreadPoolExecutor解析
- hdfs java读写hdfs demo
- swing获取文本框内容_营销管理培训课件,大客服销售策略和技巧,全内容PPT拿来就用...
- java中的抽象类(abstract)
- java 游戏 异步框架_基于Java的轻量级异步编程框架
- 选择SMA射频连接头的注意事项
- 乐高魔方机器人编程及图纸_LEGO 机器人魔方还原基本方法与过程
- html5接金币游戏源码,利用HTML5实现Canvas聚宝盆接金币游戏
- 直方图均衡化取整怎么计算_玩转直方图处理之直方图均衡化、规定化
- 视频拍摄技巧——构图
- Oracle:获取数据库系统的当前时间
- 为什么react选择了函数式组件(剖析原理)
- 前端算法js:跳格子游戏
- 我擦!硬盘文件全被人删了!!
热门文章
- WGCNA加权基因共表达网络分析(1)简介、原理
- GB:徐健/王师/黄适合作开发微生物组测序新方法2bRAD-M
- SCImago Journal Rank:微生物领域期刊综合评价指标排名
- 微生物组—宏基因组分析专题研讨会(线上课已开通,可以报名,线下课程时间待定)...
- 水稻微生物组时间序列分析2a-相关分析
- matlab中sinks,MATLAB Simulink模块库详解(二)Sinks篇
- R语言层次聚类:通过内平方和WSS选择最优的聚类K值、可视化不同K下的BSS和WSS、通过Calinski-Harabasz指数(准则)与聚类簇个数的关系获取最优聚类簇的个数
- R语言ggplot2可视化将图例移动到分面图(facet)中的空白分面区域实战
- R语言is.na函数实战(删除、替换、统计、条件判断等)
- 深度学习时间序列预测:LSTM算法构建时间序列单变量模型预测空气质量(PM2.5)+代码实战