C++如何获取数组的最大值和最小值_C++ min_element与max_element算法

使用min_element和max_element可获取数组最值,需包含algorithm头文件,解引用迭代器得值,支持自定义比较规则,但空容器会导致未定义行为。

在C++中,获取数组的最大值和最小值可以通过标准库中的 min_elementmax_element 算法轻松实现。这两个函数定义在 algorithm 头文件中,适用于数组、vector 等容器。

使用 min_element 与 max_element

std::min_element 返回指向范围中最小元素的迭代器,std::max_element 返回指向最大元素的迭代器。需要解引用才能获取实际值。

基本用法示例:

#include 
#include 
using namespace std;

int main() {
    int arr[] = {3, 7, 2, 9, 1, 5};
    int n = sizeof(arr) / sizeof(arr[0]);

    // 获取最小值和最大值
    int min_val = *min_element(arr, arr + n);
    int max_val = *max_element(arr, arr + n);

    cout << "最小值: " << min_val << endl;
    cout << "最大值: " << max_val << endl;

    return 0;
}

作用于 vector 或其他容器

对于 std::vector,可以结合 begin() 和 end() 使用:

#include 
#include 
#include 
using namespace std;

int main() {
    vector vec = {10, -2, 8, 15, 0};

    int min_val = *min_element(vec.begin(), vec.end());
    int max_val = *max_element(vec.begin(), vec.end());

    cout << "最小值: " << min_val << endl;
    cout << "最大值: " << max_val << endl;

    return 0;
}

自定义比较规则

如果需要按特定规则比较,比如找绝对值最大或最小的元素,可以传入自定义比较函数或 lambda 表达式:

// 找绝对值最小的元素
int abs_min = *min_element(arr, arr + n, [](int a, int b) {
    return abs(a) < abs(b);
});

注意:若数组为空,调用 *min_element*max_element 会导致未定义行为,使用前应确保容器非空。

基本上就这些。掌握 min_element 和 max_element 能让代码更简洁高效。