[C++] 배열에서 최대값, 최소값 찾기 (3가지 방법)

C스타일의 배열이나 std::vector, std::array의 요소들 중에 최대 값을 찾거나 최소 값을 찾는 방법을 소개합니다.

1. 반복문으로 최소, 최대 값 찾기

가장 단순한 방법은 for 반복문으로 요소의 모든 값을 순회하면서 최소, 최대 값을 찾는 것입니다.

#include <iostream>
#include <climits>

int main() {

    int arr[] = { 11, 42, -5, 9, -8, 34, 0 };

    int min = INT_MAX;
    int max = INT_MIN;
    for (int i: arr)
    {
        if (i < min) {
            min = i;
        }

        if (i > max) {
            max = i;
        }
    }

    std::cout << "min: " << min << std::endl;
    std::cout << "max: " << max << std::endl;

    return 0;
}

Output:

min: -8
max: 42

2. std::max_element()으로 최소, 최대 값 찾기

min_element(begin, end)max_element(begin, end) 함수는 인자로 전달된 배열의 begin부터 end까지의 요소들 중에 최소, 최대 값을 찾습니다.

함수는 최대, 최소 값에 해당하는 객체 주소를 리턴하기 때문에, *을 사용하여 value를 읽어야 합니다.

2.1 C스타일의 배열

C스타일 배열의 경우, begin은 배열의 시작 주소, end는 배열의 시작 주소에 배열 크기를 더하면 배열의 끝 주소가 됩니다. 이렇게 최대, 최소 값을 찾을 수 있습니다. 배열의 크기는 sizeof를 이용하여 계산할 수 있습니다.

#include <iostream>
#include <algorithm>

int main() {

    int arr[] = { 11, 42, -5, 9, -8, 34, 0 };
    int size = sizeof(arr) / sizeof(*arr);

    int min = *std::min_element(arr, arr + size);
    int max = *std::max_element(arr, arr + size);

    std::cout << "min: " << min << std::endl;
    std::cout << "max: " << max << std::endl;

    return 0;
}

Output:

min: -8
max: 42

위의 예제에서는 배열의 마지막 요소의 주소 값을 계산할 때 sizeof를 사용하였는데 std::begin(arr)std::end(arr)를 사용하면 굳이 배열 크기를 직접 계산할 필요는 없습니다. 아래 코드의 실행 결과는 위와 동일합니다.

#include <iostream>
#include <algorithm>

int main() {

    int arr[] = { 11, 42, -5, 9, -8, 34, 0 };

    int min = *std::min_element(std::begin(arr), std::end(arr));
    int max = *std::max_element(std::begin(arr), std::end(arr));

    std::cout << "min: " << min << std::endl;
    std::cout << "max: " << max << std::endl;

    return 0;
}

2.2 std::vector

vector의 경우도 min_element(), max_element()의 사용 방법은 동일합니다. 대신 vector는 begin()end() 함수를 제공하기 때문에 주소 값을 따로 계산할 필요는 없습니다.

#include <iostream>
#include <algorithm>
#include <vector>

int main() {

    std::vector<int> arr = { 11, 42, -5, 9, -8, 34, 0 };

    int min = *std::min_element(arr.begin(), arr.end());
    int max = *std::max_element(arr.begin(), arr.end());

    std::cout << "min: " << min << std::endl;
    std::cout << "max: " << max << std::endl;

    return 0;
}

Output:

min: -8
max: 42

2.3 std::array

std::array의 경우도 사용 방법은 vector와 동일합니다.

#include <iostream>
#include <algorithm>
#include <array>

int main() {

    std::array<int, 7> arr = { 11, 42, -5, 9, -8, 34, 0 };

    int min = *std::min_element(arr.begin(), arr.end());
    int max = *std::max_element(arr.begin(), arr.end());

    std::cout << "min: " << min << std::endl;
    std::cout << "max: " << max << std::endl;

    return 0;
}

Output:

min: -8
max: 42

3. std::minmax_element()으로 최소, 최대 값 찾기

std::minmax_element(begin, end)는 begin부터 end까지의 요소들 중에 최소, 최대 값을 찾아서 결과를 std::pair로 리턴합니다. 리턴되는 값은 찾은 객체의 주소 값이기 때문에 *으로 value를 읽어야 합니다.

3.1 C스타일의 배열

아래와 같이 최소, 최대 값을 찾을 수 있습니다. 리턴되는 pair의 first가 최소 값, second가 최대 값이 됩니다.

#include <iostream>
#include <algorithm>

int main() {

    int arr[] = { 11, 42, -5, 9, -8, 34, 0 };
    int size = sizeof(arr) / sizeof(*arr);

    std::pair<int*, int*> minmax = std::minmax_element(std::begin(arr), std::end(arr));

    std::cout << "min: " << *(minmax.first) << std::endl;
    std::cout << "max: " << *(minmax.second) << std::endl;

    return 0;
}

Output:

min: -8
max: 42

3.2 std::vector

vector도 배열과 동일한 방법으로 최대, 최소 값을 가져올 수 있습니다.

vector의 경우 리턴되는 std::pair<>의 타입이 매우 긴데, 그냥 auto로 결과를 받을 수 있습니다.

#include <iostream>
#include <algorithm>
#include <vector>

int main() {

    std::vector<int> arr = { 11, 42, -5, 9, -8, 34, 0 };

    auto minmax = std::minmax_element(arr.begin(), arr.end());
    // std::pair<std::vector<int>::iterator, std::vector<int>::iterator> minmax =
    //         std::minmax_element(arr.begin(), arr.end());

    std::cout << "min: " << *(minmax.first) << std::endl;
    std::cout << "max: " << *(minmax.second) << std::endl;

    return 0;
}

Output:

min: -8
max: 42

3.3 std::array

std::array의 경우도 사용 방법은 vector와 동일합니다.

#include <iostream>
#include <algorithm>
#include <array>

int main() {

    std::array<int, 7> arr = { 11, 42, -5, 9, -8, 34, 0 };

    auto minmax = std::minmax_element(arr.begin(), arr.end());

    std::cout << "min: " << *(minmax.first) << std::endl;
    std::cout << "max: " << *(minmax.second) << std::endl;

    return 0;
}

Output:

min: -8
max: 42
Loading script...
codechachaCopyright ©2019 codechacha