PHP Самая короткая / самая длинная строка в массиве

StackOverflow https://stackoverflow.com/questions/3713517

Вопрос

у меня есть множество как это

$data = array(
    "163",
    "630",
    "43",
    "924",
    "4",
    "54"
);

Как я могу выбрать самые маленькие и самые большие ценности от него Согласно длине строки Не число значение. (для этого примера это 1 (наименьшее) и 3 (самая большая).

Это было полезно?

Решение

Похоже, вы должны использовать array_map ()

  // Convert array to an array of string lengths
$lengths = array_map('strlen', $data);

  // Show min and max string length
echo "The shortest is " . min($lengths) .
     ". The longest is " . max($lengths);

Обратите внимание, что то $lengths Массив несоответствует, поэтому вы можете легко получить соответствующий номер для каждой длины строки.

Другие советы

Вот улучшенная версия Код Брайана_д:

$min = PHP_INT_MAX;
$max = -1;

foreach ($data as $a) {
    $length = strlen($a);
    $max = max($max, $length);
    $min = min($min, $length);
}

Хотя в этом случае это не рекомендуется, потому что вы будете пересекать массив дважды, вы также можете использовать Array_reduce. сравнить каждый элемент против остальных. Как это:

<?php

$data = array('163','630','43','42','999','31');
//Will return the longest element that is nearest to the end of the array (999)
//That's why we use strlen() on the result.
$max_l = strlen(array_reduce($data,'maxlen'));
//Will return the shortest element that is nearest to the end of the array (31)
$min_l = strlen(array_reduce($data,'minlen'));

echo "The longest word is $max_l characters, while the shortest is $min_l\n";

function maxlen($k,$v) {
        if (strlen($k) > strlen($v)) return $k;
        return $v;
}
function minlen($k,$v) {
        if ($k == '') return PHP_INT_MAX;
        if (strlen($k) < strlen($v)) return $k;
        return $v;
}
?>

Если вы используете PHP 5.3.0+, вы можете воспользоваться замыкание:

<?php
   $max_l = strlen(array_reduce($data,
                function ($k,$v) { return (strlen($k) > strlen($v)) ? $k : $v; }
        ));

   $min_l = strlen(array_reduce($data,
                function ($k,$v) {
                        if (!$k) return PHP_INT_MAX;
                        return (strlen($k) < strlen($v)) ? $k : $v;
                }
        ));

echo "The longest word is $max_l characters, while the shortest is $min_l\n";
?>
$min = 100;
$max = -1;

foreach($data as $a){
  $length = strlen($a);
  if($length > $max){ $max = $length; }
  else if($length < $min){ $min = $length; }
}
<?php
$array = array(
    "163",
    "630",
    "43",
    "924",
    "4",
    "54"
);
$arraycopy  = array_map('strlen',$array);
asort($arraycopy);

$min = reset($arraycopy);

//if you need a single 'minword'
$minword = $array[key($arraycopy)];
//if you need them all
$minwords = array_intersect_key($array,array_flip(array_keys($arraycopy,$min)));


$max = end($arraycopy);
//if you need a single 'maxword'
$maxword = $array[key($arraycopy)];
//if you need them all:
$maxwords = array_intersect_key($array,array_flip(array_keys($arraycopy,$max)));

var_dump($min,$max,$minword,$maxword,$minwords,$maxwords);

Для завершения здесь есть одноклассник для максимального и минимума:

$maximum = max(array_map('strlen', $array));
$minimum = min(array_map('strlen', $array));
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top