最大最小相关算法
算法名称 |
描述 |
max(a, b) |
返回两个元素中较大的一个,return _Left < _Right ? _Right : _Left; |
max(a, b, pred) |
使用谓词作大小比较,return _Pred(_Left, _Right) ? _Right : _Left; |
max_element(beg,end) |
返回迭代器,指向[beg, end)中最大的元素,默认是max_element(_First, _Last, less<>{}) |
max_element(beg,end, pred) |
使用谓词作为判断条件,返回迭代器 |
min(a, b) |
返回两个元素中较小的一个,return _Right < _Left ? _Right : _Left; |
min(a, b, pred) |
使用谓词作大小比较,return _Pred(_Right, _Left) ? _Right : _Left; |
min_element(beg,end) |
返回迭代器,指向[beg, end)中最小的元素,默认是return _STD min_element(_First, _Last, less<>{}); |
min_element(beg,end, pred) |
使用谓词作为判断条件,返回迭代器 |
最大最小相关示例
code:
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void test01()
{
int array1[6] = { 22, 44, 31, 6, 25, -70};
for (int i_loop = 0; i_loop < sizeof(array1) / sizeof(array1[0]); i_loop++)
cout << array1[i_loop] << " ";
cout << "array1中最大的数是: " << * (max_element(array1, array1 + 6)) << endl;
cout << "array1中最小的数是: " << * (min_element(array1, array1 + 6)) << endl;
cout << "array1中绝对值最大的数是: " << *(max_element(array1, array1 + 6, [](int a, int b) -> bool {return abs(a) < abs(b);})) << endl;
cout << endl;
}
void test02()
{
int a = 5;
int b = 10;
cout << "更大的数是: " << max(a, b) << endl;
cout << "更小的数是: " << min(a, b) << endl;
cout << "第一个数加6和第二个数比较,更大的是: " << max(a, b, [](int a, int b) -> bool {return a + 6 < b;}) << endl;
}
void main()
{
test01();
test02();
system("pause");
}
result:
22 44 31 6 25 -70 array1中最大的数是: 44
array1中最小的数是: -70
array1中绝对值最大的数是: -70
更大的数是: 10
更小的数是: 5
第一个数加6和第二个数比较,更大的是: 5
请按任意键继续. . .