Пространства имён
Варианты
Действия

cpp/algorithm/max element — различия между версиями

Материал из cppreference.com
< cpp‎ | algorithm
м (r2.7.3) (робот добавил: en, es, fr, ja, pt)
(Translated from the English version using Google Translate)
Строка 1: Строка 1:
{{title|max_element}}
+
{{
Синтаксис:
+
title|max_element}}
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
  
<syntaxhighlight lang="cpp">
+
, ),
  #include <algorithm>
+
  forward_iterator max_element( forward_iterator start, forward_iterator end );
+
  forward_iterator max_element( forward_iterator start, forward_iterator end, BinPred p );
+
</syntaxhighlight>
+
  
Функция max_element() возвращает итератор на наибольший элемент из диапазона [start,end).
+
 +
 +
,
 +
 +
 +
 +
end
  
Если задан бинарный предикат p, то он используется вместо оператора < для определения максимального элемента.
+
 +
, .
  
Например, следующий код использует функцию max_element() для определения максимального элемента в массиве целых чисел и максимального элемента в векторе символов:
+
 +
,():
  
<syntaxhighlight lang="cpp">
+
==
  int array[] = { 3, 1, 4, 1, 5, 9 };
+
{
  unsigned int array_size = sizeof(array) / sizeof(array[0]);
+
1
  cout << "Max element in array is " << *max_element(array, array+array_size) << endl;
+
 +
,
 +
 +
 +
;
 +
 +
=
 +
 +
()
 +
()
 +
;
 +
 +
 +
 +
 +
 +
<
 +
max_element(,
 +
 +
 +
 +
 +
 +
 +
+
 +
)
 +
 +
;
 +
 +
 +
 +
 +
  
  vector<char> v;
+
  v.push_back('a'); v.push_back('b'); v.push_back('c'); v.push_back('d');
+
  cout << "Max element in the vector v is " << *max_element(v.begin(), v.end()) << endl;
+
</syntaxhighlight>
+
 +
<>
 +
 +
<vector
 +
<>
  
Этот код выводит следующее:
+
 +
 +
:
 +
  
<syntaxhighlight lang="text">
+
  Max element in array is 9
+
  Max element in the vector v is d
+
vectorv
</syntaxhighlight>
+
<>
  
Смотрите также: [[cpp/algorithm/max | max]], [[cpp/algorithm/min | min]], [[cpp/algorithm/min_element | min_element]]
+
:
 +
 +
 
 +
 +
 +
 +
 +
 +
 +
 +
 
 +
 +
 +
cpp/algorithm/
 +
| cpp/algorithm/
 +
| cpp/algorithm/
 +
  
[[en:cpp/algorithm/max element]]
 
 
[[es:cpp/algorithm/max element]]
 
[[es:cpp/algorithm/max element]]
 
[[fr:cpp/algorithm/max element]]
 
[[fr:cpp/algorithm/max element]]
 
[[ja:cpp/algorithm/max element]]
 
[[ja:cpp/algorithm/max element]]
 
[[pt:cpp/algorithm/max element]]
 
[[pt:cpp/algorithm/max element]]
 +

Версия 07:00, 26 октября 2012

 
 
Библиотека алгоритмов
Ограниченные алгоритмы и алгоритмы над диапазонами (C++20)
Ограниченные алгоритмы, например ranges::copy, ranges::sort, ...
Политики исполнения (C++17)
Немодифицирующие операции над последовательностями
(C++11)(C++11)(C++11)
(C++17)
Модифицирующие операции над последовательностями
Операции разбиения
Операции сортировки
(C++11)
Операции двоичного поиска
Операции с наборами (в отсортированных диапазонах)
Операции с кучей
(C++11)
Операций минимума/максимума
max_element
(C++11)
(C++17)

Операции перестановки
Числовые операции
Операции с неинициализированной памятью
(C++17)
(C++17)
(C++17)
Библиотека C
 
Заголовочный файл <algorithm>
template< class ForwardIt >
ForwardIt max_element( ForwardIt first, ForwardIt last );
(1)
template< class ForwardIt, class Compare >
ForwardIt max_element( ForwardIt first, ForwardIt last, Compare comp );
(2)

Finds the greatest element in the range [first, last). The first version uses operator< to compare the values, the second version uses the given comparison function comp.

Содержание

Параметры

first, last -
вперед итераторы определении диапазона для изучения
Оригинал:
forward iterators defining the range to examine
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
cmp comparison function which returns ​true if if *a is less than *b.

The signature of the comparison function should be equivalent to the following:

bool cmp(const Type1 &a, const Type2 &b);

The signature does not need to have const &, but the function must not modify the objects passed to it.
Типы Type1 и Type2 должны быть таковы, что объект типа ForwardIt может быть разыменован и затем неявно преобразован в оба из них. ​

Требования, накладываемые на типы
-
ForwardIt должен соответствовать требованиям ForwardIterator.

Возврат стоимости

Iterator to the greatest element in the range [first, last). If several elements in the range are equivalent to the greatest element, returns the iterator to the first such element. Returns last if the range is empty.

Сложность

Именно max(N-1,0) сравнений, где N = std::distance(first, last).
Оригинал:
Exactly max(N-1,0) comparisons, where N = std::distance(first, last).
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Возможные реализации

Первый вариант
template<class ForwardIt>
ForwardIt max_element(ForwardIt first, ForwardIt last)
{
    if (first == last) {
        return last;
    }
    ForwardIt largest = first;
    ++first;
    for (; first != last; ++first) {
        if (*largest < *first) {
            largest = first;
        }
    }
    return largest;
}
Второй вариант
template<class ForwardIt, class Compare>
ForwardIt max_element(ForwardIt first, ForwardIt last,
                            Compare comp)
{
    if (first == last) {
        return last;
    }
    ForwardIt largest = first;
    ++first;
    for (; first != last; ++first) {
        if (comp(*largest, *first)) {
            largest = first;
        }
    }
    return largest;
}

Пример

#include <algorithm>
#include <iostream>
#include <vector>
#include <cmath>
 
static bool abs_compare(int a, int b)
{
    return (std::abs(a) < std::abs(b));
}
 
int main()
{
    std::vector<int> v{ 3, 1, -14, 1, 5, 9 };
    std::vector<int>::iterator result;
 
    result = std::max_element(v.begin(), v.end());
    std::cout << "max element at: " << std::distance(v.begin(), result) << '\n';
 
    result = std::max_element(v.begin(), v.end(), abs_compare);
    std::cout << "max element (absolute) at: " << std::distance(v.begin(), result);
}

Вывод:

max element at: 5
max element (absolute) at: 2

См. также

Шаблон:cpp/algorithm/dcl list min elementШаблон:cpp/algorithm/dcl list minmax elementШаблон:cpp/algorithm/dcl list max