max

(PHP 4, PHP 5)

maxFind highest value

Description

mixed max ( array $values )
mixed max ( mixed $value1 , mixed $value2 [, mixed $... ] )

If the first and only parameter is an array, max() returns the highest value in that array. If at least two parameters are provided, max() returns the biggest of these values.

Note:

PHP will evaluate a non-numeric string as 0 if compared to integer, but still return the string if it's seen as the numerically highest value. If multiple arguments evaluate to 0, max() will return a numeric 0 if given, else the alphabetical highest string value will be returned.

Parameters

values

An array containing the values.

value1

Any comparable value.

value2

Any comparable value.

...

Any comparable value.

Return Values

max() returns the numerically highest of the parameter values. If multiple values can be considered of the same size, the one that is listed first will be returned.

When max() is given multiple arrays, the longest array is returned. If all the arrays have the same length, max() will use lexicographic ordering to find the return value.

When given a string it will be cast as an integer when comparing.

Examples

Example #1 Example uses of max()

<?php
echo max(13567);  // 7
echo max(array(245)); // 5

// When 'hello' is cast as integer it will be 0. Both the parameters are equally
// long, so the order they are given in determines the result
echo max(0'hello');     // 0
echo max('hello'0);     // hello

echo max('42'3); // '42'

// Here 0 > -1, so 'hello' is the return value.
echo max(-1'hello');    // hello

// With multiple arrays of different lengths, max returns the longest
$val max(array(222), array(1111)); // array(1, 1, 1, 1)

// With multiple arrays of the same length, max compares from left to right
// using lexicographic order, so in our example: 2 == 2, but 4 < 5
$val max(array(248), array(257)); // array(2, 5, 7)

// If both an array and non-array are given, the array
// is always returned as it's seen as the largest
$val max('string', array(257), 42);   // array(2, 5, 7)
?>

See Also

  • min() - Find lowest value
  • count() - Count all elements in an array, or something in an object

Коментарии

Regarding boolean parameters in min() and max():

(a) If any of your parameters is boolean, max and min will cast the rest of them to boolean to do the comparison.
(b) true > false
(c) However, max and min will return the actual parameter value that wins the comparison (not the cast).

Here's some test cases to illustrate:

1.  max(true,100)=true
2.  max(true,0)=true
3.  max(100,true)=100
4.  max(false,100)=100
5.  max(100,false)=100
6.  min(true,100)=true
7.  min(true,0)=0
8.  min(100,true)=100
9.  min(false,100)=false
10. min(100,false)=false
11. min(true,false)=false
12. max(true,false)=true
2006-05-02 12:27:26
http://php5.kiev.ua/manual/ru/function.max.html
Matlab users and others may feel lonely without the double argument output from min and max functions.

To have the INDEX of the highest value in an array, as well as the value itself, use the following, or a derivative:

<?php
function doublemax($mylist){
 
$maxvalue=max($mylist);
  while(list(
$key,$value)=each($mylist)){
    if(
$value==$maxvalue)$maxindex=$key;
  }
  return array(
"m"=>$maxvalue,"i"=>$maxindex);
}
?>
2007-07-04 18:00:34
http://php5.kiev.ua/manual/ru/function.max.html
I had several occasions that using max is a lot slower then using a if/then/else construct. Be sure to check this in your routines!

Ries
2008-11-09 08:36:58
http://php5.kiev.ua/manual/ru/function.max.html
Автор:
Note that max() can compare dates, so if you write something like this:

<?php
$dates 
= array('2009-02-15''2009-03-15');
echo 
max($dates);
?>

you will get: 2009-03-15.
2009-05-11 10:34:29
http://php5.kiev.ua/manual/ru/function.max.html
Автор:
Notice that whenever there is a Number in front of the String, it will be used for Comparison.

<?php

  max
('7iuwmssuxue'1); //returns 7iuwmssuxu
 
max('-7suidha', -4); //returns -4

?>

But just if it is in front of the String

<?php

  max
('sdihatewin7wduiw'3); //returns 3

?>
2010-04-10 14:27:28
http://php5.kiev.ua/manual/ru/function.max.html
Автор:
max(null, 0) = null
max(0, null) = 0
2012-02-02 08:21:16
http://php5.kiev.ua/manual/ru/function.max.html
max() (and min()) on DateTime objects compares them like dates (with timezone info) and returns DateTime object.
<?php 
$dt1 
= new DateTime('2014-05-07 18:53', new DateTimeZone('Europe/Kiev'));
$dt2 = new DateTime('2014-05-07 16:53', new DateTimeZone('UTC'));
echo 
max($dt1,$dt2)->format(DateTime::RFC3339) . PHP_EOL// 2014-05-07T16:53:00+00:00
echo min($dt1,$dt2)->format(DateTime::RFC3339) . PHP_EOL// 2014-05-07T18:53:00+03:00
?>

It works at least 5.3.3-7+squeeze17
2014-05-07 19:07:46
http://php5.kiev.ua/manual/ru/function.max.html
The simplest way to get around the fact that max() won't give the key is array_search:

<?php
$student_grades 
= array ("john" => 100"sarah" => 90"anne" => 100);
$top_student array_search(max($student_grades),$student_grades); // john
?>

This could also be done with array_flip, though overwriting will mean that it gets the last max value rather than the first:

<?php
$grades_index 
array_flip($student_grades);
$top_student $grades_index[max($student_grades)]; // anne
?>

To get all the max value keys:

<?php
$top_students 
array_keys($student_grades,max($student_grades)); // john, anne
?>
2016-07-11 19:36:42
http://php5.kiev.ua/manual/ru/function.max.html
Be aware if a array like this is used (e.g. values from a shopping cart):
<?php
Array
(
    [
0] => 142,80
   
[1] => 39,27
   
[2] => 22,80
   
[3] => 175,80
)?>
The result will be: 39,27 and not - as expected - 175,80

So, to find the max value, use integer only like:
<?php
Array
(
    [
0] => 14280
   
[1] => 3927
   
[2] => 2280
   
[3] => 17580
)?>
and you will get the correct result: 17580
2019-01-18 12:37:01
http://php5.kiev.ua/manual/ru/function.max.html
In response to: keith at bifugi dot com

If you want to find the specific key(s) that match the maximum value in an array where the values may be duplicated, you can loop through and perform a simple check:
<?php

# Example Array
$a = array(
     
'key1' => 100,
     
'key2' => 90,
     
'key3' => 100,
     
'key4' => 90,
);

# First get the maximum value
$max max($a);

# Create a new array containing all keys which have the max value
foreach($a as $key => $val) {     
     if(
$val === $max$b[] = $key;
}

# If you want a string list, just do this
$b implode(' '$b);
?>

This produces consistent results and will scale well in terms of performance, whereas functions like array_search and array_flip can lead to degraded performance when dealing with large amounts of data.
2019-10-07 11:01:25
http://php5.kiev.ua/manual/ru/function.max.html
Автор:
Watch out after PHP 8.0!

Sample code:

<?php
echo max(0,'hello');
?>

Before PHP 8.0 will return int(0) but since PHP 8.0 above code returns string("hello")!!
2022-06-22 13:57:57
http://php5.kiev.ua/manual/ru/function.max.html
Автор:
With modern PHP versions supporting the array spread operator for function arguments, it's tempting to call max() like this:

<?php
function stuff(): iterable {
   
// This function might yield 0, 1 or n values.
}

$foo max(...stuff());
?>

However, this is dangerous if you cannot guarantee that your generator yields **minimum** two values.

The gotcha here is that when max() receives a single argument, it must be an array of values. (When the generator doesn't yield any values, max() will throw an ArgumentCountError.)

If you can guarantee that your generator yields at least one value, then it's safe to call max by relying on the aforementioned array expectation:

<?php
function stuff(): iterable {
   
// This function will yield 1...n values.
}

// Note that here the generator is first read into an array.
$foo max([...stuff()]);
?>

If the array is empty, max() will throw a ValueError.

The added burden is that faulty code could appear to appear to function just fine but fails at random, probably causing a lot of head-scratching at first.
2023-10-12 10:28:28
http://php5.kiev.ua/manual/ru/function.max.html

    Поддержать сайт на родительском проекте КГБ