logo

Algorytm C++ max()

Algorytm C++ maks.() Funkcję można wykorzystać na 3 sposoby:

  • Porównuje dwie wartości przekazane w swoich argumentach i zwraca większy między nimi . Jeśli oba są równe, zwraca pierwszy.
  • Porównuje również te dwie wartości za pomocą a funkcja binarna który jest zdefiniowany przez użytkownika, a następnie przekazany jako argument w std::max().
  • Służy również do wyszukiwania największy element na danej liście i zwraca pierwszą z nich, jeśli na liście znajduje się więcej niż jedna z największych.

Elementy porównuje się za pomocą operatoracomp dla drugiej wersji.

Składnia

 default (1) template const T& max (const T& a, const T& b); //until C++ 11 custom (2) template const T& max (const T& a, const T& b, Compare comp); //until C++ 11 default (1) template const T& max (const T& a, const T& b); //until C++ 14 custom (2) template const T& max (const T& a, const T& b, Compare comp); //until C++ 14 initializer list (3) template T max (initializer_list il); template T max (initializer_list il, Compare comp); //until C++ 14 default (1) template constexpr const T& max (const T& a, const T& b); //since C++ 14 //since C++ 14 custom (2) template constexp const T& max(const T& a, const T& b, Compare comp); // since C++ 14 initializer list (3) template constexpr T max (initializer_list il); template constexpr T max (initializer_list il, Compare comp); //since C++ 14 

Parametr

A : Pierwsza wartość do porównania.

B : Druga wartość do porównania.

komp : Zdefiniowana przez użytkownika binarna funkcja predykatu, która akceptuje dwa argumenty i zwraca wartość true, jeśli oba argumenty są w odpowiedniej kolejności, w przeciwnym razie zwraca wartość false. Przestrzega ścisłej, słabej kolejności elementów.

The : Lista_inicjatorów zawierająca wartości do porównania.

Wartość zwracana

Zwraca maksimum a i b. Jeśli wartości są równoważne, zwraca a.

Zwraca największą wartość w il. Jeśli kilka wartości jest równoważnych maksimum, zwraca wartość znajdującą się najbardziej na lewo.

Złożoność

Złożoność jest liniowa o jeden mniej niż liczba porównywanych elementów.

Wyjątki

Ta funkcja zgłasza wyjątek, jeśli jakiekolwiek porównanie zgłasza wyjątek.

Uwaga: Nieprawidłowe parametry powodują niezdefiniowane zachowanie.

Przykład 1

Zobaczmy prosty przykład ilustrujący użycie max():

 #include #include #include using namespace std; int main() { cout << 'larger of 1 and 9999: ' << std::max(1, 9999) << '
' << 'larger of 'a', and 'b': ' << max('a', 'b') << '
' << 'longest of 'foo', 'bar', and 'hello': ' << max( { 'foo', 'bar', 'hello' }, [](const string& s1, const string& s2) { return s1.size() < s2.size(); }) << '
'; return 0; } 

Wyjście:

 larger of 1 and 9999: 9999 larger of 'a', and 'b': b longest of 'foo', 'bar', and 'hello': hello 

Przykład 2

Zobaczmy inny prosty przykład ilustrujący użycie max() przy użyciu wersji domyślnej:

 #include // std::cout #include // std::max using namespace std; int main () { cout << 'max(1,2)==' << max(1,2) << '
'; cout << 'max(2,1)==' << max(2,1) << '
'; cout << 'max('a','z')==' << max('a','z') << '
'; cout << 'max(3.14,2.73)==' << max(3.14,2.73) << '
'; return 0; } 

Wyjście:

 max(1,2)==2 max(2,1)==2 max('a','z')==z max(3.14,2.73)==3.14 

Przykład 3

Zobaczmy inny prosty przykład ilustrujący użycie max() przy użyciu funkcji porównania:

 #include #include using namespace std; // Defining the binary function bool comp(int a, int b) { return (a <b); } int main() { a="7;" b="28;" cout << max(a,b,comp) '
'; returns the first one if both numbers are same max(7,7,comp); return 0; < pre> <p> <strong>Output:</strong> </p> <pre> 28 7 </pre> <h2>Example 4</h2> <p>Let&apos;s see a simple example to find the maximum element in the list:</p> <pre> #include #include using namespace std; // Defining the binary function bool comp(int a, int b) { return (a <b); } int main() { finding the largest of all numbers cout << 'maximum element is: '<< max({1, 2, 3, 4, 5, 10, -1, 7},comp) '
'; return 0; < pre> <p> <strong>Output:</strong> </p> <pre> Maximum element is: 10 </pre> <br></b);></pre></b);>

Przykład 4

Zobaczmy prosty przykład znalezienia maksymalnego elementu na liście:

 #include #include using namespace std; // Defining the binary function bool comp(int a, int b) { return (a <b); } int main() { finding the largest of all numbers cout << \'maximum element is: \'<< max({1, 2, 3, 4, 5, 10, -1, 7},comp) \'
\'; return 0; < pre> <p> <strong>Output:</strong> </p> <pre> Maximum element is: 10 </pre> <br></b);>