max原型:

std::max

default (1)
template <class T> const T& max (const T& a, const T& b);
custom (2)
template <class T, class Compare>
const T& max (const T& a, const T& b, Compare comp);
initializer list (3)
template <class T> T max (initializer_list<T> il);
template <class T, class Compare>
T max (initializer_list<T> il, Compare comp);

该函数返回范围或者两个数中最大的一个。

对于(1),假设两个数相等,则返回a;

其行为类似于:

template <class T> const T& max (const T& a, const T& b) {
return (a<b)? b:a; // or: return comp(a,b)?b:a; for version (2)
}

一个简单的样例:

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
void max2(){
cout<<"max(10,22)="<<max(10,22)<<endl;
cout<<"max({1,2,5,7,9,999,888})="<<max({1,2,5,7,9,999,888})<<endl;
}

执行截图:

max_elements原型:

std::max_element

default (1)
template <class ForwardIterator>
ForwardIterator max_element (ForwardIterator first, ForwardIterator last);
custom (2)
template <class ForwardIterator, class Compare>
ForwardIterator max_element (ForwardIterator first, ForwardIterator last,
Compare comp);

返回范围内值最大那个元素的迭代器,假设存在多个同样最大值,则返回第一个。

(max返回的是元素,这个返回的是迭代器)

假设范围为空,则返回last.

使用operator<进行比較。

其行为类似于:

template <class ForwardIterator>
ForwardIterator max_element ( ForwardIterator first, ForwardIterator last )
{
if (first==last) return last;
ForwardIterator largest = first; while (++first!=last)
if (*largest<*first) // or: if (comp(*largest,*first)) for version (2)
largest=first;
return largest;
}

一个简单的样例:

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
void maxelement(){
vector<int> vi{1,1,2,3,4};
cout<<"at first vi=";
for(int i:vi)
cout<<i<<" ";
cout<<endl;
cout<<"max_element(vi.begin(),vi.end())="<<*max_element(vi.begin(),vi.end())<<endl;
cout<<"max_element(vi.begin(),vi.begin()+1)="<<*max_element(vi.begin(),vi.begin()+1)<<endl;
if(max_element(vi.end(),vi.end())==vi.end())
cout<<"max_element(vi.end(),vi.end())=vi.end()"<<endl; }

执行结果:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXE4NDQzNTIxNTU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

——————————————————————————————————————————————————————————————————

//写的错误或者不好的地方请多多指导。能够在以下留言或者点击左上方邮件地址给我发邮件,指出我的错误以及不足。以便我改动,更好的分享给大家,谢谢。

转载请注明出处:http://blog.csdn.net/qq844352155

author:天下无双

Email:coderguang@gmail.com

2014-9-17

于GDUT

——————————————————————————————————————————————————————————————————


最新文章

  1. 推荐Python Web开发测试驱动方法
  2. BZOJ1015 [JSOI2008]星球大战starwar
  3. vsftpd配置参数详细整理
  4. 2016 Multi-University Training Contest 5 World is Exploding
  5. 如何写一个漂亮的Liferay Theme 6.2
  6. IOS开发之格式化日期时间
  7. 二分求解 三角形 stl的应用 涉及范围的二分查找可以先求上界再算下界,结果即上界减下界
  8. opencl 和Renderscript总结
  9. 20145237《Java程序设计》实验报告一
  10. R语言学习——图形初阶之散点图
  11. JS学习笔记Day23
  12. CentOS 7 zabbix实现微信报警
  13. 蓝牙speaker配对流程源码分析
  14. XOR and Favorite Number CodeForces - 617E -莫队-异或前缀和
  15. JQuery button控制div或者section
  16. maven打包证(支付)书问题
  17. (转)IntelliJ IDEA java项目导入jar包,打jar包
  18. 修改form 的字段背景颜色及字体颜色
  19. 在Oracle/SQL Service中通过Function返回Table
  20. 11.Container With Most Water---两指针

热门文章

  1. JavaScript正则表达式-RegExp对象
  2. luogu3834 【模板】可持久化线段树 1(主席树)
  3. 详解Java类的生命周期
  4. HDU-5317 RGCDQ ,暴力打表!
  5. 【Luogu】P2158仪仗队(欧拉函数)
  6. BZOJ 1087 [SCOI2005]互不侵犯King ——状压DP
  7. [luoguP2606] [ZJOI2010]排列计数(DP)
  8. cf615D Multipliers
  9. jenkins异常解答
  10. EC++学习笔记(五) 实现