C++系列-STL容器中算法中的最大最小

STL容器中算法中的最大最小

最大最小相关算法

算法名称描述
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
请按任意键继续. . .
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值