C++数组、vector求最大值最小值及其下标

简介: C++数组、vector求最大值最小值及其下标

使用 <algorithm> 头文件来查找数组或向量中最大值、最小值及其索引

#include <iostream>
#include <vector>
#include <algorithm> // 包含 std::max_element 和 std::min_element


int main() {
    std::vector<int> vec = {3, 1, 4, 2, 5};

    // 查找最大值及其索引
    auto maxIt = std::max_element(vec.begin(), vec.end());
    int maxValue = *maxIt;
    int maxIndex = std::distance(vec.begin(), maxIt);

    // 查找最小值及其索引
    auto minIt = std::min_element(vec.begin(), vec.end());
    int minValue = *minIt;
    int minIndex = std::distance(vec.begin(), minIt);

    // 输出向量内容
    std::cout << "向量: ";
    for (int num : vec) {
        std::cout << num << " ";
    }
    std::cout << "\n";

    // 输出最大值及其索引
    std::cout << "最大值: " << maxValue << ",索引: " << maxIndex << "\n";
    // 输出最小值及其索引
    std::cout << "最小值: " << minValue << ",索引: " << minIndex << "\n";

    return 0;
}

解释

std::max_elementstd::min_element 函数:

std::max_element(vec.begin(), vec.end()) 返回指向向量中最大元素的迭代器。

std::min_element(vec.begin(), vec.end()) 返回指向向量中最小元素的迭代器。

std::distance(vec.begin(), maxIt)std::distance(vec.begin(), minIt) 分别计算最大元素和最小元素的索引。

注意事项:

确保在使用 std::max_elementstd::min_element 之前检查向量不为空,以避免未定义的行为。

目录
相关文章
|
4月前
|
搜索推荐 编译器 C语言
【C++核心】特殊的元素集合-数组与字符串详解
这篇文章详细讲解了C++中数组和字符串的基本概念、操作和应用,包括一维数组、二维数组的定义和使用,以及C风格字符串和C++字符串类的对比。
105 4
|
2月前
|
存储 编译器 C语言
【c++丨STL】vector的使用
本文介绍了C++ STL中的`vector`容器,包括其基本概念、主要接口及其使用方法。`vector`是一种动态数组,能够根据需要自动调整大小,提供了丰富的操作接口,如增删查改等。文章详细解释了`vector`的构造函数、赋值运算符、容量接口、迭代器接口、元素访问接口以及一些常用的增删操作函数。最后,还展示了如何使用`vector`创建字符串数组,体现了`vector`在实际编程中的灵活性和实用性。
66 4
|
17天前
|
存储 对象存储 C++
C++ 中 std::array<int, array_size> 与 std::vector<int> 的深入对比
本文深入对比了 C++ 标准库中的 `std::array` 和 `std::vector`,从内存管理、性能、功能特性、使用场景等方面详细分析了两者的差异。`std::array` 适合固定大小的数据和高性能需求,而 `std::vector` 则提供了动态调整大小的灵活性,适用于数据量不确定或需要频繁操作的场景。选择合适的容器可以提高代码的效率和可靠性。
39 0
|
21天前
|
存储 编译器 C语言
【c++丨STL】vector模拟实现
本文深入探讨了 `vector` 的底层实现原理,并尝试模拟实现其结构及常用接口。首先介绍了 `vector` 的底层是动态顺序表,使用三个迭代器(指针)来维护数组,分别为 `start`、`finish` 和 `end_of_storage`。接着详细讲解了如何实现 `vector` 的各种构造函数、析构函数、容量接口、迭代器接口、插入和删除操作等。最后提供了完整的模拟实现代码,帮助读者更好地理解和掌握 `vector` 的实现细节。
30 0
|
3月前
|
存储 C++ 索引
【C++打怪之路Lv9】-- vector
【C++打怪之路Lv9】-- vector
27 1
|
3月前
|
安全 测试技术 C++
【C++篇】从零实现 C++ Vector:深度剖析 STL 的核心机制与优化2
【C++篇】从零实现 C++ Vector:深度剖析 STL 的核心机制与优化
78 6
|
3月前
|
安全 测试技术 C++
【C++篇】从零实现 C++ Vector:深度剖析 STL 的核心机制与优化1
【C++篇】从零实现 C++ Vector:深度剖析 STL 的核心机制与优化
96 7
|
3月前
|
编译器 C++
【C++】—— vector模拟实现
【C++】—— vector模拟实现
|
3月前
|
编译器 C语言 C++
【C++篇】解密 STL 动态之魂:全面掌握 C++ vector 的高效与优雅
【C++篇】解密 STL 动态之魂:全面掌握 C++ vector 的高效与优雅
62 3
|
3月前
|
C++
【C++】C++ STL探索:Vector使用与背后底层逻辑(三)
【C++】C++ STL探索:Vector使用与背后底层逻辑