> 백엔드 개발 > C++ > 본문

C의 벡터 내에서 최대값과 최소값을 효율적으로 찾는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-10-25 00:23:02
원래의
380명이 탐색했습니다.

How do I efficiently find the maximum and minimum values within a vector in C  ?

C에서 벡터의 최대값 또는 최소값 찾기

C에서 벡터의 최대값 또는 최소값을 구하는 것은 간단한 작업입니다. . STL(표준 템플릿 라이브러리) 기능을 활용하면 전체 컨테이너를 반복하지 않고도 이를 효율적으로 달성할 수 있습니다.

std::max_element() 및 std::min_element() 사용

표준 라이브러리는 각각 값 시퀀스에서 최대 요소와 최소 요소를 찾기 위한 std::max_element() 및 std::min_element() 함수를 제공합니다. 이 함수는 한 쌍의 반복자를 인수로 사용하여 검색을 수행해야 하는 범위를 나타냅니다. 반환 값은 최대/최소 값을 가진 요소를 가리키는 반복자입니다.

구문:

<code class="cpp">std::max_element(iterator_begin, iterator_end);
std::min_element(iterator_begin, iterator_end);</code>
로그인 후 복사

예:

<code class="cpp">#include <vector>
#include <algorithm>

std::vector<int> v = {1, 3, 5, 7, 9};

int max_num = *std::max_element(v.begin(), v.end());
int min_num = *std::min_element(v.begin(), v.end());

std::cout << "Maximum value: " << max_num << std::endl;
std::cout << "Minimum value: " << min_num << std::endl;</code>
로그인 후 복사

배열과 벡터 사용

벡터와 배열은 모두 C에서 컨테이너입니다. 그러나 벡터는 동적이지만 배열은 정적입니다. 따라서 최대값/최소값을 구하는 접근 방식이 약간 다릅니다.

배열의 경우 요소에 직접 액세스하고 배열을 반복하여 최대값/최소값을 결정할 수 있습니다.

예:

<code class="cpp">int arr[] = {1, 3, 5, 7, 9};
int size = sizeof(arr) / sizeof(arr[0]);

int max_num = arr[0];
int min_num = arr[0];

for (int i = 1; i < size; i++) {
    max_num = std::max(max_num, arr[i]);
    min_num = std::min(min_num, arr[i]);
}

std::cout << "Maximum value: " << max_num << std::endl;
std::cout << "Minimum value: " << min_num << std::endl;</code>
로그인 후 복사

결론적으로 std::max_element() 및 std::min_element()를 사용하는 것은 벡터에서 최대값과 최소값을 찾는 편리한 방법입니다. 배열의 경우 요소를 반복하여 동일한 결과를 얻을 수 있습니다.

위 내용은 C의 벡터 내에서 최대값과 최소값을 효율적으로 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!