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

发布于:2024-10-10 ⋅ 阅读:(62) ⋅ 点赞:(0)

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
请按任意键继续. . .

网站公告

今日签到

点亮在社区的每一天
去签到